# F<sup>2</sup>MC-8L 8-BIT MICROCONTROLLER MB89202/F202RA Series HARDWARE MANUAL # F<sup>2</sup>MC-8L 8-BIT MICROCONTROLLER MB89202/F202RA Series HARDWARE MANUAL Be sure to refer to the "Check Sheet" for the latest cautions on development. "Check Sheet" is seen at the following support page URL:http://www.fujitsu.com/global/services/microelectronics/product/micom/support/index.html "Check Sheet" lists the minimal requirement items to be checked to prevent problems beforehand in system development. #### **PREFACE** #### ■ Purpose of This Manual and Intended Reader The MB89202/F202RA series was developed as one of the general-purpose products of the F<sup>2</sup>MC-8L family, which contains original 8-bit one-chip microcontrollers for use with ASICs (application specific ICs). The MB89202/F202RA series can be used in a wide range of products from consumer products to industrial products. This manual explains the functions and operations of the MB89202/F202RA series for product development. The F<sup>2</sup>MC-8L Programming Manual contains details of the programming instructions. Note: F<sup>2</sup>MC, an abbreviation for FUJITSU Flexible Microcontroller, is a registered trademark of FUJITSU LIMITED. #### ■ Trademark The company names and brand names herein are the trademarks or registered trademarks of their respective owners. #### ■ Structure of This Manual This manual consists of the following 17 chapters and appendix. #### **CHAPTER 1 OVERVIEW** This chapter describes the features and basic specification of the MB89202/F202RA series. #### **CHAPTER 2 HANDLING DEVICES** This chapter describes the precautions to be taken when handling the MB89202/F202RA series. #### **CHAPTER 3 CPU** This chapter describes the functions and operation of the CPU. #### **CHAPTER 4 I/O PORTS** This chapter describes the functions and operation of the I/O ports. #### **CHAPTER 5 TIME-BASE TIMER** This chapter describes the functions and operation of the time-base timer. #### **CHAPTER 6 WATCHDOG TIMER** This chapter describes the functions and operation of the watchdog timer. #### **CHAPTER 7 8-BIT PWM TIMER** This chapter describes the functions and operation of the 8-bit PWM timer. #### **CHAPTER 8 8/16-BIT CAPTURE TIMER/COUNTER** This chapter describes the functions and operation of the 8/16-bit capture timer/counter. #### **CHAPTER 9 12-BIT PPG TIMER** This chapter describes the functions and operation of the 12-bit PPG timer. #### CHAPTER 10 EXTERNAL INTERRUPT CIRCUIT 1 (EDGE) This chapter describes the functions and operation of external interrupt circuit 1 (edge). #### **CHAPTER 11 EXTERNAL INTERRUPT CIRCUIT 2 (LEVEL)** This chapter describes the functions and operation of external interrupt circuit 2 (level). #### **CHAPTER 12 A/D CONVERTER** This chapter describes the functions and operation of the A/D converter. #### **CHAPTER 13 UART** This chapter describes the functions and operation of UART. #### CHAPTER 14 8-BIT SERIAL I/O This chapter describes the functions and operation of the 8-bit serial I/O. #### **CHAPTER 15 BUZZER OUTPUT** This chapter describes the functions and operation of the buzzer output. #### **CHAPTER 16 WILD REGISTER FUNCTIONS** This chapter describes the functions and operation of the wild registers. #### **CHAPTER 17 FLASH MEMORY** This chapter describes the functions and operation of the flash memory. #### **APPENDIX** This appendix shows the I/O map and instructions list. - The contents of this document are subject to change without notice. Customers are advised to consult with sales representatives before ordering. - The information, such as descriptions of function and application circuit examples, in this document are presented solely for the purpose of reference to show examples of operations and uses of FUJITSU semiconductor device; FUJITSU does not warrant proper operation of the device with respect to use based on such information. When you develop equipment incorporating the device based on such information, you must assume any responsibility arising out of such use of the information. FUJITSU assumes no liability for any damages whatsoever arising out of the use of the information. - Any information in this document, including descriptions of function and schematic diagrams, shall not be construed as license of the use or exercise of any intellectual property right, such as patent right or copyright, or any other right of FUJITSU or any third party or does FUJITSU warrant non-infringement of any third-party's intellectual property right or other right by using such information. FUJITSU assumes no liability for any infringement of the intellectual property rights or other rights of third parties which would result from the use of information contained herein. - The products described in this document are designed, developed and manufactured as contemplated for general use, including without limitation, ordinary industrial use, general office use, personal use, and household use, but are not designed, developed and manufactured as contemplated (1) for use accompanying fatal risks or dangers that, unless extremely high safety is secured, could have a serious effect to the public, and could lead directly to death, personal injury, severe physical damage or other loss (i.e., nuclear reaction control in nuclear facility, aircraft flight control, air traffic control, mass transport control, medical life support system, missile launch control in weapon system), or (2) for use requiring extremely high reliability (i.e., submersible repeater and artificial satellite). - Please note that FUJITSU will not be liable against you and/or any third party for any claims or damages arising in connection with above-mentioned uses of the products. - Any semiconductor devices have an inherent chance of failure. You must protect against injury, damage or loss from such failures by incorporating safety design measures into your facility and equipment such as redundancy, fire protection, and prevention of over-current levels and other abnormal operating conditions. - Exportation/release of any products described in this document may require necessary procedures in accordance with the regulations of the Foreign Exchange and Foreign Trade Control Law of Japan and/or US export control laws. - The company names and brand names herein are the trademarks or registered trademarks of their respective owners. #### **READING THIS MANUAL** #### **■** Example Notation of Register Names and Pin Names #### O Example notation of register names and bit names If interrupt enabled ( $\underline{CCR}: \underline{I} = \underline{1}$ ) is specified, the interrupt is accepted. Current state Bit abbreviation Register abbreviation #### O Example notation of multi-use pins #### P33/EC pin Some pins can switch functions according to a setting made by a program or other method. These pins are called multi-use pins. For multi-use pins, the names corresponding to functions are listed and divided by /. #### **CONTENTS** | CHAPTI | ER 1 OVERVIEW | 1 | |--------|--------------------------------------------------|----| | 1.1 | Features of MB89202/F202RA Series | 2 | | 1.2 | MB89202/F202RA Series Product Lineup | 4 | | 1.3 | Differences between Models | | | 1.4 | Block Diagram of MB89202/F202RA Series | 7 | | 1.5 | Pin Assignment | 8 | | 1.6 | Package Dimensions | 10 | | 1.7 | Pin Functions Description | 12 | | 1.8 | I/O Circuit Types | 14 | | CHAPTI | ER 2 HANDLING DEVICES | 17 | | 2.1 | Precautions on Handling Devices | 18 | | CHAPTI | ER 3 CPU | 21 | | 3.1 | Memory Space | 22 | | 3.1.1 | Specific-purpose Areas | 24 | | 3.1.2 | Location of 16-bit Data on Memory | 26 | | 3.2 | Dedicated Register | 27 | | 3.2.1 | Condition Code Register (CCR) | 29 | | 3.2.2 | Register Bank Pointer (RP) | 31 | | 3.3 | General-Purpose Registers | 32 | | 3.4 | Interrupts | 34 | | 3.4.1 | Interrupt Level Setting Registers (ILR1 to ILR4) | 36 | | 3.4.2 | Steps in the Interrupt Operation | 37 | | 3.4.3 | Multiple Interrupts | 39 | | 3.4.4 | Interrupt Processing Time | 40 | | 3.4.5 | Stack Operation at Interrupt Processing | 41 | | 3.4.6 | Stack Area for Interrupt Processing | 42 | | 3.5 | Reset | 43 | | 3.5.1 | Reset Flag Register (RSFR) | 45 | | 3.5.2 | External Reset Pin | 47 | | 3.5.3 | Reset Operation | 48 | | 3.5.4 | State of Each Pin at Reset | 50 | | 3.6 | Clock | 51 | | 3.6.1 | Clock Generator | 53 | | 3.6.2 | | | | 3.6.3 | System Clock Control Register (SYCC) | 56 | | 3.6.4 | | | | 3.6.5 | | | | 3.7 | Standby Mode (Low-Power Consumption Mode) | 62 | | 3.7.1 | Operations in Standby Mode | 63 | | 3.7.2 | Sleep Mode | 64 | | 3.7.3 | Stop Mode | 65 | | 3.7. | .4 Standby Control Register (STBC) | 66 | |------|-------------------------------------------------|-----| | 3.7. | .5 Diagram for State Transition in Standby Mode | 68 | | 3.7. | .6 Notes on Standby Mode | 70 | | 3.8 | Memory Access Mode | 72 | | CHAP | TER 4 I/O PORTS | 75 | | 4.1 | Overview of I/O Ports | 76 | | 4.2 | Port 0 | 78 | | 4.2. | .1 Registers of Port 0 (PDR0, DDR0, and PUL0) | 80 | | 4.2. | .2 Operations of Port 0 Functions | 82 | | 4.3 | Port 3 | 84 | | 4.3. | .1 Registers of Port 3 (PDR3, DDR3, PUL3) | 86 | | 4.3. | .2 Operations of Port 3 Functions | 88 | | 4.4 | Port 4 | | | 4.4. | .1 Registers of Port 4 (PDR4) | 92 | | 4.4. | -1 | | | 4.5 | Port 5 | | | 4.5. | | | | 4.5. | • | | | 4.6 | Port 6 | | | 4.6. | | | | 4.6. | <b>'</b> | | | 4.7 | Port 7 | | | 4.7. | -3 , , , , , , , , , , , , , , , , , | | | 4.7. | • | | | 4.8 | Programming Example of I/O Port | 113 | | CHAP | TER 5 TIME-BASE TIMER | 115 | | 5.1 | Overview of Time-base Timer | | | 5.2 | Configuration of Time-base Timer | | | 5.3 | Time-base Timer Control Register (TBTC) | | | 5.4 | Interrupt of Time-base Timer | | | 5.5 | Operations of Time-base Timer Functions | | | 5.6 | Notes on Using Time-base Timer | | | 5.7 | Program Example for Time-base Timer | 125 | | CHAP | TER 6 WATCHDOG TIMER | 127 | | 6.1 | Overview of Watchdog Timer | 128 | | 6.2 | Configuration of Watchdog Timer | 129 | | 6.3 | Watchdog Control Register (WDTC) | 130 | | 6.4 | Operations of Watchdog Timer Functions | | | 6.5 | Notes on Using Watchdog Timer | 132 | | 6.6 | Program Example for Watchdog Timer | 133 | | <b>CHAPT</b> | ER 7 8-BIT PWM TIMER | 135 | |--------------|-------------------------------------------------------|-----| | 7.1 | Overview of 8-bit PWM Timer | 136 | | 7.2 | Configuration of 8-bit PWM Timer | 139 | | 7.3 | Pin of 8-bit PWM Timer | | | 7.4 | Registers of 8-bit PWM Timer | 142 | | 7.4.1 | PWM Control Register (CNTR) | 143 | | 7.4.2 | | | | 7.5 | Interrupt of 8-bit PWM Timer | | | 7.6 | Operations of the Interval Timer Functions | 148 | | 7.7 | Operations of the 8-bit PWM Timer Functions | 150 | | 7.8 | States in Each Mode During Operation | 152 | | 7.9 | Notes on Using 8-bit PWM Timer | 155 | | 7.10 | Program Example for PWM Timer | 157 | | CHAPT | ER 8 8/16-BIT CAPTURE TIMER/COUNTER | 161 | | 8.1 | Overview of 8/16-bit Capture Timer/Counter | 162 | | 8.2 | Configuration of 8/16-bit Capture Timer/Counter | | | 8.3 | Pins of 8/16-bit Capture Timer/Counter | | | 8.4 | Registers of 8/16-bit Capture Timer/Counter | | | 8.4.1 | · | | | 8.4.2 | . , , , | | | 8.4.3 | • • • • | | | 8.4.4 | Timer Output Control Register (TCR2) | 177 | | 8.4.5 | | | | 8.4.6 | - , , | | | 8.4.7 | , , | | | 8.5 | 8/16-bit Capture Timer/Counter of Interrupts | | | 8.6 | Explanation of Operations of Interval Timer Functions | | | 8.7 | Operation of Counter Functions | | | 8.8 | Functions of Operations of Capture Functions | 193 | | 8.9 | 8/16-bit Capture Timer/Counter Operation in Each Mode | 197 | | 8.10 | Notes on Using 8/16-bit Capture Timer/Counter | 198 | | 8.11 | Program Example for 8/16-bit Capture Timer/Counter | 200 | | CHAPT | ER 9 12-BIT PPG TIMER | 205 | | 9.1 | Overview of 12-bit PPG Timer | 206 | | 9.2 | Configuration of 12-bit PPG Timer Circuit | 209 | | 9.3 | Pin of 12-bit PPG Timer | | | 9.4 | Registers of 12-bit PPG Timer | 213 | | 9.4.1 | - | | | 9.4.2 | , , | | | 9.4.3 | 5 ( ) | | | 9.4.4 | · · · · · · · · · · · · · · · · · · · | | | 9.5 | Operations of 12-bit PPG Timer Functions | | | 9.6 | Notes on Using 12-bit PPG Timer | | | 9.7 | Program Example for 12-bit PPG Timer | | | СНАРТ | ER 10 EXTERNAL INTERRUPT CIRCUIT 1 (EDGE) | 225 | |-------|--------------------------------------------------|-----| | 10.1 | Overview of External Interrupt Circuit 1 | | | 10.2 | Configuration of External Interrupt Circuit 1 | | | 10.3 | Pins of External Interrupt Circuit 1 | 229 | | 10.4 | Registers of External Interrupt Circuit 1 | | | 10.4 | · | | | 10.4 | · · · · · · · · · · · · · · · · · · · | | | 10.5 | Interrupt of External Interrupt Circuit 1 | | | 10.6 | Operations of External Interrupt Circuit 1 | | | 10.7 | Program Example for External Interrupt Circuit 1 | | | СНАРТ | ER 11 EXTERNAL INTERRUPT CIRCUIT 2 (LEVEL) | 243 | | 11.1 | Overview of External Interrupt Circuit 2 | 244 | | 11.2 | Configuration of External Interrupt Circuit 2 | 245 | | 11.3 | Pins of External Interrupt Circuit 2 | 246 | | 11.4 | Registers of External Interrupt Circuit 2 | 249 | | 11.4 | 1 External Interrupt 2 Control Register (EIE2) | 250 | | 11.4 | .2 External Interrupt 2 Flag Register (EIF2) | 252 | | 11.5 | Interrupt of External Interrupt Circuit 2 | 253 | | 11.6 | Operations of External Interrupt Circuit 2 | 254 | | 11.7 | Program Example for External Interrupt Circuit 2 | 256 | | СНАРТ | ER 12 A/D CONVERTER | 259 | | 12.1 | Overview of A/D Converter | 260 | | 12.2 | Configuration of A/D Converter | 261 | | 12.3 | Pins of A/D Converter | 263 | | 12.4 | Registers of A/D Converter | 265 | | 12.4 | 1 A/D Control Register 1 (ADC1) | 266 | | 12.4 | 2 A/D Control Register 2 (ADC2) | 268 | | 12.4 | 3 A/D Data Register (ADDH and ADDL) | 270 | | 12.4 | .4 A/D Enable Register (ADEN) | 271 | | 12.5 | Interrupt of A/D Converter | 272 | | 12.6 | Operations of A/D Converter Functions | 273 | | 12.7 | Notes on Using A/D Converter | 275 | | 12.8 | Program Example for A/D Converter | 277 | | СНАРТ | ER 13 UART | 279 | | 13.1 | Overview of UART | 280 | | 13.2 | Configuration of UART | 284 | | 13.3 | Pins of UART | 287 | | 13.4 | Registers of UART | 289 | | 13.4 | Serial Mode Control Register (SMC) | 290 | | 13.4 | .2 Serial Rate Control Register (SRC) | 292 | | 13.4 | 3 Serial Status and Data Register (SSD) | 294 | | 13.4 | .4 Serial Input Data Register (SIDR) | 297 | | 13.4 | .5 Serial Output Data Register (SODR) | 298 | | 13 / | 6 Clock Divider Selection Register (LIPC) | 200 | | 13.4 | 4.7 Serial Switch Register (SSEL) | 301 | |-------|---------------------------------------------------------|-----| | 13.5 | Interrupt of UART | 303 | | 13.6 | Operations of UART Functions | 304 | | 13.6 | Transmission Operations (Operating Mode 0, 1, 2, and 3) | 306 | | 13.6 | Reception Operations (Operating Mode 0, 1, or 3) | 307 | | 13.6 | 8.3 Reception Operations (Operating Mode 2 Only) | 309 | | 13.7 | Program Example for UART | 311 | | СНАРТ | TER 14 8-BIT SERIAL I/O | 313 | | 14.1 | Overview of 8-Bit Serial I/O | 314 | | 14.2 | Configuration of 8-Bit Serial I/O | 315 | | 14.3 | Pins of 8-Bit Serial I/O | 317 | | 14.4 | Registers of 8-Bit Serial I/O | 319 | | 14.4 | 1.1 Serial Mode Register (SMR) | 320 | | 14.4 | 1.2 Serial Data Register (SDR) | 323 | | 14.5 | Interrupt of 8-Bit Serial I/O | 324 | | 14.6 | Operations of Serial Output Functions | 325 | | 14.7 | Operations of Serial Input Functions | 327 | | 14.8 | 8-Bit Serial I/O Operation in Each Mode | | | 14.9 | Notes on Using 8-Bit Serial I/O | 333 | | 14.10 | Example of 8-Bit Serial I/O Connection | 334 | | 14.11 | Program Example for 8-Bit Serial I/O | 336 | | СНАРТ | TER 15 BUZZER OUTPUT | 339 | | 15.1 | Overview of the Buzzer Output | 340 | | 15.2 | Configuration of the Buzzer Output | 341 | | 15.3 | Pin of the Buzzer Output | 342 | | 15.4 | Buzzer Register (BZCR) | 343 | | 15.5 | Program Example for Buzzer Output | 345 | | СНАРТ | TER 16 WILD REGISTER FUNCTION | 347 | | 16.1 | Overview of the Wild Register Function | 348 | | 16.2 | Configuration of the Wild Register Function | 349 | | 16.3 | Registers of the Wild Register Function | 350 | | 16.3 | B.1 Data Setting Registers (WRDR0 and WRDR1) | 351 | | 16.3 | 3.2 Higher Address Set Registers (WRARH0 and WRARH1) | 352 | | 16.3 | 3.3 Lower Address Set Registers (WRARL0 and WRARL1) | 353 | | 16.3 | 3.4 Address Comparison EN Register (WREN) | 354 | | 16.3 | 3.5 Data Test Set Register (WROR) | 355 | | 16.4 | Operations of the Wild Register Functions | | | CHAPTER 17 FLASH MEMORY | 357 | |--------------------------------------------------------------|-----| | 17.1 Overview of Flash Memory | | | 17.2 Flash Memory Control Status Register (FMCS) | | | 17.3 Starting the Flash Memory Automatic Algorithm | | | 17.4 Confirming the Automatic Algorithm Execution State | 362 | | 17.4.1 Data Polling Flag (DQ7) | 363 | | 17.4.2 Toggle Bit Flag (DQ6) | | | 17.4.3 Timing Limit Exceeded Flag (DQ5) | | | 17.4.4 Toggle Bit-2 Flag (DQ2) | | | 17.5 Detailed Explanation of Writing to Erasing Flash Memory | | | 17.5.1 Setting The Read/Reset State | | | 17.5.2 Writing Data | | | 17.5.3 Erasing All Data (Erasing Chips) | 371 | | 17.6 Flash Security Feature | | | 17.7 Notes on using Flash Memory | 373 | | APPENDIX | 375 | | APPENDIX A I/O Map | 376 | | APPENDIX B Overview of the Instructions | | | B.1 Addressing | 383 | | B.2 Special Instructions | 387 | | B.3 Bit Manipulation Instructions (SETB and CLRB) | 391 | | B.4 F <sup>2</sup> MC-8L Instructions List | 392 | | B.5 Instruction Map | | | APPENDIX C Mask Options | 400 | | APPENDIX D Programming EPROM with Evaluation Chip | 401 | | APPENDIX E Pin State of the MB89202/F202RA Series | 402 | | INDEX | 403 | ### Main changes in this edition | Page | Changes (For details, refer to main body.) | | | |------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | - | - | The followings product name is changed. (MB89202 →MB89202/F202RA) | | | | | The followings term is changed. (source oscillation →oscillation frequency) | | | 6 | 1.3 Differences between Models | "Notes:" is changed. (The followings sentence is deleted. "• At turning on the power, when the device is used without inputting the external reset, select "reset output supported" and "power-on reset supported" by mask option.") | | | | | The followings package is changed in Table 1.3-1. (FPT-34P-M03 →FPT-32P-M03) | | | 12 | 1.7 Pin Functions | RST pin in Table 1.7-1 is changed. | | | 19 | 2.1 Precautions on<br>Handling Devices | "● External pull-up for the External Reset Pin (\overline{RST}) of MB89F202/F202RA" is changed. | | | 24 | 3.1.1 Specific-purpose | The summary is changed. | | | | Areas | "■ General-purpose Register Area (address: 0100 <sub>H</sub> to 01FF <sub>H</sub> )" is changed. | | | | | "■ Vector Table Area (Address: FFC0 <sub>H</sub> to FFFF <sub>H</sub> )" is changed. | | | 44 | 3.5 Reset | "● Power-on reset" is changed. | | | | | "Note:" is deleted. | | | 56 | 3.6.3 System Clock | Figure 3.6-5 is changed. | | | 57 | Control Register (SYCC) | Table 3.6-1 is changed. | | | 130 | 6.3 Watchdog Control<br>Register (WDTC) | Figure 6.3-1 is changed. | | | 186 | 8.6 Explanation of<br>Operations of Interval<br>Timer Functions | "● 8-bit mode"is changed. (The followings sentence is deleted. "The initial value of the square wave output is "L" level. The square wave output is initialized by writing "0" to the TSTR bit of the timer control register (TCR).") | | | 264 | 12.3 Pins of A/D<br>Converter | "■ Block Diagram of the Pins Related to the A/D Converter" is changed. ("Note:" is deleted.) | | | 308 | 13.6.2 Reception<br>Operations (Operating<br>Mode 0, 1, or 3) | "■ Reception Operations (Operating Mode 0, 1, or 3)" is changed. ("Note:" is changed.) | | | Page | Changes (For details, refer to main body.) | | | |------|-----------------------------------------------------------|-------------------------------------------------------------------------------------|--| | 310 | 13.6.3 Reception<br>Operations (Operating<br>Mode 2 Only) | "■ Reception Operations (Operating Mode 2 Only)" is changed. ("Note:" is changed.) | | | 358 | 17.1 Overview of Flash<br>Memory | "■ High voltage supply on RST pin (applicable to MB89F202RA only)" is added. | | | 370 | 17.5.2 Writing Data | Figure 17.5-1 is changed. (F555 →F554) | | | 394 | B.4 F <sup>2</sup> MC-8L<br>Instructions List | Table B.4-2 is changed. ("No.22 DECW A" is changed.) | | The vertical lines marked in the left side of the page show the changes. # CHAPTER 1 OVERVIEW This chapter describes the features and basic specification of the MB89202/F202RA series. - 1.1 Features of MB89202/F202RA Series - 1.2 MB89202/F202RA Series Product Lineup - 1.3 Differences between Models - 1.4 Block Diagram of MB89202/F202RA Series - 1.5 Pin Assignment - 1.6 Package Dimensions - 1.7 Pin Functions Description - 1.8 I/O Circuit Types #### 1.1 Features of MB89202/F202RA Series The MB89202/F202RA series contains general-purpose single-chip microcontrollers that incorporate a full range of peripheral functions such as A/D converter, UART, PWM timer, PPG, capture timer/counter and external interrupts as well as a compact instruction set. #### **■** Features of MB89202/F202RA Series #### • F<sup>2</sup>MC-8L CPU core - Instruction set most suitable for controllers - Multiplication and division instruction - 16-bit operation - Branch instruction by bit test - Bit operation instruction, and others #### 4-system timers - 8/16-bit capture timer/counter (8-bit capture timer/counter + 8-bit timer or 16-bit capture timer/counter) - 8-bit PWM timer (also available as an interval timer) - 21-bit time-base timer - Watchdog timer #### • 10-bit A/D converter - 10-bit A/D $\times$ 8 channels - Activation by 8/16-bit capture timer/counter output is possible. #### Programmable pulse generator (PPG) • Pulse width and cycle are software selectable (12-bit PPG). #### UART • 6, 7, or 8 transfer data length #### 8-bit serial I/O - · Available when switched from UART - LSB first/MSB first selectability #### External interrupts • External interrupt 1 (edge detection × 3 pins) has three independent inputs and can be used for wake-up from low-power consumption mode. (The edge detection can be selected from rising-edge, falling-edge, and both-edge modes.) • External interrupt 2 (level detection × 8 pins, 1 channel) has eight independent inputs and can be used for wake-up from low-power consumption mode. (L level detection function is supported.) #### Low-power consumption modes (standby modes) - Stop mode (The oscillation is stopped so that current consumption is minimal.) - Sleep mode (The CPU is stopped so that the current consumption is reduced by one-third of normal consumption.) #### Up to 26 pins of I/O ports • General-purpose I/O ports (CMOS): 26 pins (4 of which can be used as N-ch open-drain I/O ports.) #### Wild registers - 2-byte data at two addresses are available. - When a specific address or data is used on a wild register, the data in the ROM area is changed. #### 16 KB Flash with read protection • Once the protection code is written in the specified address, the FLASH content cannot be read by parallel/serial programmer. #### 1.2 MB89202/F202RA Series Product Lineup Four MB89202 series models are available. Table 1.2-1 shows the models and Table 1.2-2 shows the CPU and peripheral functions. #### ■ MB89202/F202RA Series Models Table 1.2-1 MB89202/F202RA Series Models | | MB89201 | MB89F202/F202RA | MB89V201 | |--------------------------------------|--------------------------------------|----------------------------------------|-------------------------------------| | Classification | Evaluation product (for development) | Flash memory product (read protection) | Mask ROM product | | ROM size | 32K × 8 bits<br>(External EPROM*2) | 16K × 8 bits<br>(Internal Flash) | 16K × 8 bits<br>(Internal mask ROM) | | RAM size | 512 × 8 bits | | | | Low-power consumption (standby mode) | Sleep mode and stop mode | | | | Process | CMOS | | | | Operating voltage*1 | 2.7V to 5.5V | 3.5V to 5.5V | 2.2V to 5.5V | <sup>\*1:</sup> The minimum operating voltage varies with conditions such as operating frequency, functions, and connecting ICE. <sup>\*2:</sup> MBM27C256A is used as the external ROM. Table 1.2-2 CPU and Peripheral Functions of MB89202/F202RA Series | Ite | em | Specification | | | |-------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | CPU f | unction | Number of basic instructions: Instruction bit length: Instruction length: Data bit length: Minimum instruction execution time: Instruction length: Output Data bit length: Minimum instruction execution time: Output Data bit length: Da | | | | | Port | General-purpose I/O port: 26 pins (Also serve as peripherals. 4 of which can be used as N-ch open-drain I/O ports.) | | | | | 21-bit<br>time-base<br>timer | 21 bits Interrupt cycle: 0.66 ms, 2.64 ms, 21 ms, or 335.5 ms with 12.5MHz main clock | | | | | Watchdog<br>timer | Reset occurrence cycle: When the main clock is at 12.5 MHz (minimum 335.5 ms) | | | | | 8-bit<br>PWM<br>timer | 8-bit interval timer operation (Square wave output is supported. Operating clock cycle: 1 t <sub>INST</sub> , 16 t <sub>INST</sub> , 64 t <sub>INST</sub> , and 8/16-bit capture timer/counter output) 8-bit resolution PWM operation (Conversion cycle: 256 t <sub>INST</sub> , 4096 t <sub>INST</sub> , 16384 t <sub>INST</sub> and 256 times 8/16-bit capture timer/counter output) | | | | | 8/16-bit<br>capture<br>timer/<br>counter | 8-bit capture timer/counter × 1 channel + 8-bit timer or 16-bit capture timer/counter × 1 channel When timer 0 or a 16-bit counter is operating, event-counting operation by external clock input and square wave output are supported. | | | | Periphera | UART | Transfer data length: 6, 7, or 8 bits | | | | 1 function | 8-bit serial I/O | 8 bits length, LSB first/MSB first selectability One clock selectable from four operation clocks (one external shift clock, three internal shift clocks: 2 t <sub>INST</sub> , 8 t <sub>INST</sub> , 32 t <sub>INST</sub> ) | | | | | 12-bit<br>PPG timer | Output frequency: Pulse width and cycle are selectable. | | | | | External interrupt 1 (wake-up) | 3 channels (interrupt vector, request flag, and request output enable) Edge selectability (selectable from rising edge, falling edge, and both-edge modes) Also available for wake-up from stop or sleep (Edge detection is also available in stop mode.) | | | | | External interrupt 2 (wake-up) | 8 inputs 1 channel (L level interrupt and input enable are independent.) Also available for wake-up from stop or sleep (Level detection is also available in stop mode.) | | | | | 10-bit A/D converter | 10-bit resolution × 8 channels A/D conversion function (Conversion time: 38 t <sub>INST</sub> ) Continuous activation by 8/16-bit capture timer/counter output or time-base timer output. | | | | Wild register 8-bit × 2 | | $8$ -bit $\times$ 2 | | | #### Note: The oscillation is 12.5 MHz unless another condition such as the main clock maximum speed, the clock cycle value, or conversion time is stated. #### 1.3 Differences between Models This section describes the precautions to be taken when selecting a MB89202/F202RA series model. #### ■ Precautions when Selecting a Model Table 1.3-1 Differences between Models | Package | MB89201 | MB89F202/F202RA | MB89V202 | |-------------|---------|-----------------|----------| | DIP-32P-M06 | × | 0 | 0 | | FPT-32P-M03 | × | 0 | 0 | | FPT-64P-M03 | 0 | × | × | #### Current consumption • When operated at a low speed, the current consumption of a model with a flash is greater than that of a model with a mask ROM, though the current consumption in sleep or stop mode is the same. #### **Notes:** - For details on each package, see Section "1.6 Package Dimensions ". - For details on current consumption and electrical characteristics of A/D converter, see the electrical characteristics in the Data Sheet. #### 1.4 Block Diagram of MB89202/F202RA Series #### Figure 1.4-1 shows the block diagram of the MB89202/F202RA series. #### ■ Block Diagram of MB89202/F202RA Series #### 1.5 Pin Assignment Figure 1.5-1 and Figure 1.5-2 show the pin assignment of the MB89202/F202RA series. #### ■ Pin Assignment of DIP-32P-M06 Figure 1.5-1 Pin Assignment of DIP-32P-M06 P04/INT24 32 ■ Vcc P05/INT25 31 P03/INT23/AN7 P06/INT26 □ P02/INT22/AN6 3 30 P07/INT27 ☐ P01/INT21/AN5 29 P60 [ P00/INT20/AN4 5 28 P61 🗀 27 ☐ P43/AN3\* 6 RST $\square$ ☐ P42/AN2\* 7 26 X0 🗆 8 ☐ P41/AN1\* X1 □ 9 24 ☐ P40/AN0\* 23 ☐ P72\* Vss \_\_\_ 10 P37/BZ/PPG 22 ☐ P71\* ☐ P70\* P36/INT12 21 P35/INT11 \_\_\_\_ 20 ☐ P50/PWM P34/TO/INT10 □ ☐ P30/UCK/SCK 14 19 P33/EC \_\_\_\_ 15 18 ☐ P31/UO/SO ☐ P32/UI/SI С <u></u> 16 17 \*: Large-current drive type #### ■ Pin Assignment of FPT-34P-M03 Figure 1.5-2 Pin Assignment of FPT-34P-M03 Note: N.C.: Do not use because it is connected internally. #### 1.6 Package Dimensions Two different packages are available for MB89202/F202RA series. Figure 1.6-1 and Figure 1.6-2 show package dimensions. #### ■ Package Dimension of DIP-32P-M06 32-pin plastic SH-DIP Lead pitch Low space 10.16 mm Sealing method Plastic mold (DIP-32P-M06) Figure 1.6-1 Package Dimension of DIP-32P-M06 Please confirm the latest Package dimension by following URL. http://edevice.fujitsu.com/fj/DATASHEET/ef-ovpklv.html #### ■ Package Dimension of FPT-34P-M03 34-pin plastic SSOP Lead pitch 0.65 mm Package width × $6.10 \times 11.00 \text{ mm}$ package length Lead shape Gullwing Sealing method Plastic mold Mounting height 1.45 mm MAX Code P-SSOP34-6.1×11-0.65 (Reference) (FPT-34P-M03) Figure 1.6-2 Package Dimension of FPT-34P-M03 Please confirm the latest Package dimension by following URL. http://edevice.fujitsu.com/fj/DATASHEET/ef-ovpklv.html #### 1.7 Pin Functions Description Table 1.7-1 describes the I/O pins and functions. The letters in the circuit type column shown in Table 1.7-1 correspond to the letters in the Circuit Type column shown in Table 1.8-1. #### **■** Pin Functions Description Table 1.7-1 Pin Functions Description (1/2) | Pin No. | | Pin | Circuit | Function | | |-----------|----------|-------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | SHDIP32*1 | SSOP34*2 | name | type | Function | | | 8 | 8 | X0 | A | Pins for connecting the crystal for the main clock. To use an | | | 9 | 9 | X1 | | external clock, input the signal to X0 and leave X1 open. | | | 5, 6 | 5, 6 | P60,<br>P61 | H/E | General-purpose CMOS input port. | | | 7 | 7 | RST | С | Reset I/O pin. This pin serves as an N-ch open-drain reset output and a reset input as well. The reset is a hysteresis input. It outputs the "L" signal in response to an internal reset request. Also, it initializes the internal circuit upon input of the "L" signal. | | | 28, 29 | 30, 31 | P00/<br>INT20/<br>AN4,<br>P01/<br>INT21/<br>AN5 | G | General-purpose CMOS I/O ports. These pins also serve as an input (wake-up input) of external interrupt 2 or as an 10-bit A/D converter analog input. The input of external interrupt 2 is a hysteresis input. | | | 30, 31 | 32, 33 | P02/<br>INT22/<br>AN6,<br>P03/<br>INT23/<br>AN7 | G | General-purpose CMOS I/O ports. These pins also serve as an input (wake-up input) of external interrupt 2 or as an 10-bit A/D converter analog input. The input of external interrupt 2 is a hysteresis input. | | | 1 to 4 | 1 to 4 | P04/<br>INT24<br>to<br>P07/<br>INT27 | D | General-purpose CMOS I/O ports. These pins also serve as an input (wake-up input) of external interrupt 2. The input of external interrupt 2 is a hysteresis input. | | | 19 | 20 | P30/<br>UCK/<br>SCK | В | General-purpose CMOS I/O ports. This pin also serves as the clock I/O pin for the UART or 8-bit serial I/O. The resource is a hysteresis input. | | | 18 | 19 | P31/<br>UO/SO | Е | General-purpose CMOS I/O ports. This pin also serves as the data output pin for the UART or 8-bit serial I/O. | | Table 1.7-1 Pin Functions Description (2/2) | Pin No. | | Pin | Circuit | Function | | |-----------|----------|-------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | SHDIP32*1 | SSOP34*2 | name | type | Function | | | 17 | 18 | P32/UI/<br>SI | В | General-purpose CMOS I/O ports. This pin also serves as the data input pin for the UART or 8-bit serial I/O. The resource is a hysteresis input. | | | 15 | 15 | P33/EC | В | General-purpose CMOS I/O ports. This pin also serves as the external clock input pin for the 8/16-bit capture timer/counter. The resource is a hysteresis input. | | | 14 | 14 | P34/<br>TO/<br>INT10 | В | General-purpose CMOS I/O ports. This pin also serves as the output pin for the 8/16-bit capture timer/counter or as the input pin for external interrupt 1. The resource is a hysteresis input. | | | 13 | 13 | P35/<br>INT11 | В | General-purpose CMOS I/O ports. These pins also serve as the input pin for external interrupt 1. The resource is a hysteresis input. | | | 12 | 12 | P36/<br>INT12 | В | General-purpose CMOS I/O ports. These pins also serve as the input pin for external interrupt 1. The resource is a hysteresis input. | | | 11 | 11 | P37/<br>BZ/<br>PPG | Е | General-purpose CMOS I/O ports. This pin also serves as the buzzer output pin or the 12-bit PPG output pin. | | | 20 | 21 | P50/<br>PWM | Е | General-purpose CMOS I/O ports. This pin also serves as the 8-bit PWM timer output pin. | | | 24 to 27 | 26 to 29 | P40/<br>AN0 to<br>P43/<br>AN3 | F | General-purpose CMOS I/O ports. These pins can also be used as N-ch open-drain ports. These pins also serve as 10-bit A/D converter analog input pins. | | | 21 to 23 | 23 to 25 | P70 to<br>P72 | Е | General-purpose CMOS I/O ports. | | | 32 | 34 | V <sub>CC</sub> | | Power supply pin | | | 10 | 10 | V <sub>SS</sub> | | Power (GND) pin | | | 16 | 17 | С | | MB89F202/F202RA: Capacitance pin for regulating the power supply. Connect an external ceramic capacitor of about 0.1μF. MB89202: This pin is not internally connected. It is unnecessary to connect a capacitor. | | | | 16, 22 | N.C. | | Internally connected pins Be sure to leave it open. | | \*1 : DIP-32P-M06 \*2 : FPT-34P-M03 #### 1.8 I/O Circuit Types Table 1.8-1 describes the I/O circuit types. The letters in the circuit column shown in Table 1.8-1 correspond to the letters in the circuit type column shown in Table 1.7-1. #### ■ I/O Circuit Types Table 1.8-1 I/O Circuit Types (1/2) | Types | Circuit | Remarks | |-------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A | X1 X0 X0 X0 X0 X1 X0 X1 | At an oscillation feedback resistance of approximately 500 $\ensuremath{\mathrm{k}} \Omega$ | | В | P-ch N-ch Input enable Port / Resource | CMOS output Hysteresis input Pull-up resistor optional | | С | P-ch with pull-up, not available for MB89F202/F202RA N-ch Reset | At an output pull-up resistor (P-ch) of approximately 50 k $\Omega$ /5.0 V (not available for MB89F202/F202RA) N-ch open-drain reset output Hysteresis input High voltage input tolerable in MB90F202RA | Table 1.8-1 I/O Circuit Types (2/2) | Types | Circuit | Remarks | |-------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | D | P-ch N-ch Input enable Resource | CMOS output CMOS input Hysteresis input (Resource input) Pull-up resistor optional | | Е | P-ch P-ch N-ch Port | CMOS output CMOS input Pull-up resistor optional P70 to P72 are large current drive type | | F | P-ch Open-drain control N-ch Analog input Input enable A/D enable | CMOS output CMOS input Analog input N-ch open-drain output available P40 to P43 are large current drive type | | G | Input enable | CMOS output CMOS input Hysteresis input (Resource input) Analog input | | Н | Input enable———Port | CMOS input | #### CHAPTER 1 OVERVIEW ## **CHAPTER 2** # HANDLING DEVICES This chapter describes the precautions to be taken when handling general-purpose one-chip microcontrollers. 2.1 Precautions on Handling Devices #### 2.1 Precautions on Handling Devices This section describes the precautions to be taken when handling the power supply voltage, pins, and other device items. #### ■ Precautions on Handling Devices #### Ensure that the voltage does not exceed the maximum ratings. (Preventing latch-up) A latch-up may occur if a voltage higher than Vcc or lower than Vss is applied to input or output pins other than middle- or high-level resistant pins, or if voltage exceeding the rated value is applied between Vcc and Vss. When a latch-up occurs, the supply current increases rapidly, occasionally resulting in overheating. Therefore, ensure that the voltage does not exceed the maximum ratings when using the microcontrollers. #### Stabilize the supply voltage as much as possible Although the specified Vcc supply voltage operating range is assured, a sudden change in the supply voltage within the specified range may result in a malfunction. The following stabilization guidelines are recommended: The Vcc ripple (P-P value) at the supply frequency (50 Hz to 60 Hz) should be less than 10% of the typical Vcc value, and the transient fluctuation rate should be less than 0.1 V/ms at the time of momentary fluctuation when switching the power supply. #### Handling unused input pins Leaving unused input pins open may result in a malfunction or equipment damage due to a latch-up. Therefore, set these pins to pull-up or pull-down via resistors of $2\,k\Omega$ or higher. #### Handling the N.C. pins Ensure that the N.C. (internally connected) pins are opened before using. #### Precautions on using an external clock When an external clock is used, the oscillation stabilization wait time is also provided for power-on reset and stop mode release. #### Wild register function Because wild registers cannot be debugged on MB89V201, check operation on an actual MB89F202/F202RA. #### Program execution on RAM When MB89V201 is used, a program cannot be executed on RAM. #### Note to Noise in the External Reset Pin (RST) If the reset pulse applied to the external reset pin $(\overline{RST})$ does not meet the specifications, it may cause malfunctions. Use caution so that the reset pulse less than the specifications will not be fed to the external reset pin $(\overline{RST})$ . #### ● External pull-up for the External Reset Pin (RST) of MB89F202/F202RA Internal pull-up control for $\overline{RST}$ is not available for MB89F202/F202RA. To ensure proper external reset control in MB89F202/F202RA, an external pull-up (recommend 100 k $\Omega$ ) for $\overline{RST}$ pin must be required. For MB89F202RA only, high voltage must be applied to $\overline{RST}$ during flash memory program / erase. The typical high voltage is 10 V. #### Step-down circuit stabilization time The MB89202/F202RA series consists of the products listed in Table 2.1-1 "Pin Processing for the Products with and without a Step-down Circuit". The operation characteristic depends on whether a product contains a step-down circuit. Table 2.1-1 Pin Processing for the Products with and without a Step-down Circuit | Product name | Operating voltage | Step-down circuit | |-----------------|-------------------|-------------------| | MB89V201 | 2.7 V to 5.5 V | Not contained | | MB89202 | 2.2 V to 5.5 V | Not contained | | MB89F202/F202RA | 3.5 V to 5.5 V | Contained | These products use the same internal resources. However, the operation sequence after power-on reset depends on whether a product contains a step-down circuit. Figure 2.1-1 shows the sequence of operations after the power-on reset for each model. Figure 2.1-1 Operation Sequences after Power-on Reset between Product Types As shown in Figure 2.1-1, the start of CPU operation of a product with a step-down circuit is slower than that of the product without a step-down circuit. This is because time is required for the step-down circuit to stabilize prior to normal operation of the step-down circuit. # **CHAPTER 3** # CPU This chapter describes the functions and operations of the CPU. - 3.1 Memory Space - 3.2 Dedicated Register - 3.3 General-Purpose Registers - 3.4 Interrupts - 3.5 Reset - 3.6 Clock - 3.7 Standby Mode (Low-Power Consumption Mode) - 3.8 Memory Access Mode # 3.1 Memory Space The MB89202/F202RA series has 64-KB memory space that consists of the I/O area, RAM area, ROM area, and external area. Part of the memory space is applied for specific use such as general-purpose registers or a vector table. ## ■ Configuration of Memory Space ## I/O area (address: 0000<sub>H</sub> to 007F<sub>H</sub>) The control registers and data registers for built-in peripheral functions are assigned. The I/O area is assigned as part of the memory space, thus access to the I/O area can be obtained in the same manner as access to memory. Also, direct addressing provides high-speed access. #### RAM area Static RAM is equipped as the internal data area. The size of internal RAM depends on the model. Direct addressing allows high-speed access to an area from $80_H$ to $FF_H$ . (Some models restrict the usable range of the area.) 100<sub>H</sub> to 1FF<sub>H</sub> can be used as the general-purpose register area. If a reset occurs while data is being written into RAM, the data being written cannot be guaranteed. #### ROM area ROM is equipped as the internal program area. The size of internal ROM depends on the model. $FFCO_H$ to $FFFF_H$ are usable as a vector table or another feature. # **■** Memory Map Figure 3.1-1 Memory Map # 3.1.1 Specific-purpose Areas In addition to the I/O area, the general-purpose register area and vector table area are available as areas for specific applications. # ■ General-purpose Register Area (Address: 0100<sub>H</sub> to 01FF<sub>H</sub>) - This area is used for 8-bit arithmetic operations and transfer. Supplementary registers are provided. - Since this area is allocated to a part of the RAM area, it can also be used as normal RAM. - When this area is used as a general-purpose register, it can be accessed faster using shorter instructions by general-purpose register addressing. For details, see Section "3.2.2 Register Bank Pointer (RP)" and Section "3.3 General-Purpose Registers". ## ■ Vector Table Area (Address: FFC0<sub>H</sub> to FFFF<sub>H</sub>) - This area is used as vector tables of the vector call instructions, interrupts, and reset. - This area is allocated to the highest ranges of the ROM area, and the start address of the corresponding processing routine is set to the address of each vector table. Table 3.1-1 provides the reference addresses in the vector table that correspond to the vector instructions, interrupts, and reset. For details, see Section "3.4 Interrupts ", Section "3.5 Reset ", and "CALLV #vct" in APPENDIX "B.2 Special Instructions ". Table 3.1-1 Vector Table (1/2) | Vector call instruction | Address in the vector table | | | |-------------------------|-----------------------------|-------------------|--| | vector can instruction | Upper digits | Lower digits | | | CALLV #0 | FFC0 <sub>H</sub> | FFC1 <sub>H</sub> | | | CALLV #1 | FFC2 <sub>H</sub> | FFC3 <sub>H</sub> | | | CALLV #2 | FFC4 <sub>H</sub> | FFC5 <sub>H</sub> | | | CALLV #3 | FFC6 <sub>H</sub> | FFC7 <sub>H</sub> | | | CALLV #4 | FFC8 <sub>H</sub> | FFC9 <sub>H</sub> | | | CALLV #5 | FFCA <sub>H</sub> | FFCB <sub>H</sub> | | | CALLV #6 | FFCC <sub>H</sub> | FFCD <sub>H</sub> | | | CALLV #7 | FFCE <sub>H</sub> | FFCF <sub>H</sub> | | | IRQF | FFDC <sub>H</sub> | FFDD <sub>H</sub> | | | IRQE | FFDE <sub>H</sub> | FFDF <sub>H</sub> | | | IRQD | FFE0 <sub>H</sub> | FFE1 <sub>H</sub> | | | IRQC | FFE2 <sub>H</sub> | FFE3 <sub>H</sub> | | Table 3.1-1 Vector Table (2/2) | Vector cell instruction | Address in the vector table | | | |-------------------------|-----------------------------|-------------------|--| | Vector call instruction | Upper digits | Lower digits | | | IRQB | FFE4 <sub>H</sub> | FFE5 <sub>H</sub> | | | IRQA | FFE6 <sub>H</sub> | FFE7 <sub>H</sub> | | | IRQ9 | FFE8 <sub>H</sub> | FFE9 <sub>H</sub> | | | IRQ8 | FFEA <sub>H</sub> | FFEB <sub>H</sub> | | | IRQ7 | FFEC <sub>H</sub> | FFED <sub>H</sub> | | | IRQ6 | FFEE <sub>H</sub> | FFEF <sub>H</sub> | | | IRQ5 | FFF0 <sub>H</sub> | FFF1 <sub>H</sub> | | | IRQ4 | FFF2 <sub>H</sub> | FFF3 <sub>H</sub> | | | IRQ3 | FFF4 <sub>H</sub> | FFF5 <sub>H</sub> | | | IRQ2 | FFF6 <sub>H</sub> | FFF7 <sub>H</sub> | | | IRQ1 | FFF8 <sub>H</sub> | FFF9 <sub>H</sub> | | | IRQ0 | FFFA <sub>H</sub> | FFFB <sub>H</sub> | | | Mode data | _ * | FFFD <sub>H</sub> | | | Reset vector | FFFE <sub>H</sub> | FFFF <sub>H</sub> | | <sup>\*:</sup> For MB89202 / MB89V201, FFFC $_{\rm H}$ is prohibited. (Use "FF $_{\rm H}$ ".) For MB89F202/F202RA, write "01 $_{\rm H}$ " to FFFC $_{\rm H}$ to activate read protection, otherwise write "FF $_{\rm H}$ ". # 3.1.2 Location of 16-bit Data on Memory Upper digits of 16-bit data and stack data are stored in lower addresses on memory. ## ■ 16-bit Data Storage State on RAM When 16-bit data is written into RAM, the upper byte of the data is stored with a lower address and the lower byte of the data is stored with the next address. 16-bit data is read in the same manner. Figure 3.1-2 shows the location of 16-bit data on RAM. Figure 3.1-2 Location of 16-bit Data on RAM ## ■ 16-bit Operand Storage State When 16 bits are specified for operands in instructions, upper bytes are also stored in addresses close to operation codes (instructions) and lower bytes are stored in the following addresses. Operands that indicate memory addresses and 16-bit immediate data are handled in the same manner as stated above. Figure 3.1-3 shows the locations of 16-bit data in instructions. Figure 3.1-3 Location of 16-bit Data in Instructions ## ■ 16-bit Data Storage State in Stack The upper byte of data for a 16-bit register put in the stack due to an interrupt is also stored with a lower address. # 3.2 Dedicated Register The dedicated register in the CPU consists of a program counter (PC), two arithmetic operation registers (A and T), three address pointers (IX, EP, and SP), and program status (PS) register. The size of each register is 16 bits. ## ■ Dedicated Register Configuration The dedicated register in the CPU consists of seven 16-bit registers. Some registers allow only the lower 8 bits to be used. Figure 3.2-1 shows the configuration of the dedicated register. Initial value 16 bits PC FFFD<sub>H</sub> Program counter Indicates the current instruction stored position. Undefined Α Accumulator Temporary register that handles arithmetic operations and data transfer. Undefined Т Temporary accumulator Handles arithmetic operations together with the accumulator. Undefined ΙX Index register Indicates index address. Undefined ΕP Extra-pointer Indicates memory address. SP Undefined Stack pointer Indicates the current position in the stack. Flag I = 0CCR RP Program status register IL1 and IL0 = 11 Stores the register bank pointer and condition code. ΡS The other bits are undefined. Figure 3.2-1 Configuration of Dedicated Register ## **■** Functions of the Dedicated Register #### Program counter (PC) The size of the program counter is 16 bits. It indicates the memory address at which the CPU is currently handling an instruction. The program counter is updated with an instruction executed, interrupt, or reset. The initial value specified after the reset operation is the mode data read address ( $FFFD_H$ ). ## Accumulator (A) The accumulator is a 16-bit arithmetic operation register. It handles arithmetic operations or data transfer using data on memory or data in another register such as temporary accumulator (T). The accumulator allows data in it to be used as a word (16 bits) or bytes (8 bits). When arithmetic operations or data transfer is handled in the unit of a byte, only the lower 8 bits (AL) of the accumulator are used; the upper 8 bits (AH) remain unchanged. The initial value specified after the reset operation is undefined. #### Temporary Accumulator (T) The temporary accumulator is an auxiliary 16-bit arithmetic operation register. It handles arithmetic operations using data in the accumulator (A). When arithmetic operations in the accumulator (A) are handled in word units (16 bits), data in the temporary accumulator is handled in word units. Otherwise, it is handled in byte units (8 bits). When arithmetic operations are handled in byte units, only the lower 8 bits (TL) in the temporary accumulator are used; the upper 8 bits (TH) are not used. When an MOV instruction is used to transfer data into the accumulator (A), data stored in the accumulator is automatically transferred to the temporary accumulator before it is transferred. For data transfer in byte units, the upper 8 bits of the temporary accumulator (TH) does not change. The initial value of the temporary accumulator specified after the reset operation is undefined. #### Index register (IX) The index register is a 16-bit register that stores an index address. The index register is used together with a 1-byte offset (-128 to +127). It generates a memory address for accessing data by adding a sign-extended offset to the index address. The initial value of the index register specified after the reset operation is undefined. #### Extra-pointer (EP) The extra-pointer is a 16-bit register. Data in the extra-pointer is handled as the memory address for accessing data. The initial value of the extra-pointer specified after the reset operation is undefined. ## Stack pointer (SP) The stack pointer is a 16-bit register that stores an address that is used to call an interrupt or subroutine, or to which a stack/recovery instruction makes a reference. While a program is being executed, the value of the stack pointer indicates the address of the latest data put in the stack. The initial value of the stack pointer specified after the reset operation is undefined. #### Program status (PS) register The program status is a 16-bit control register. The upper 8 bits of the program status register is the register bank pointer (RP) used to indicate the address of a general-purpose register bank. The lower 8 bits are the condition code register (CCR) that composes flags for indicating the CPU status. Because these 8-bit registers comprise the program status register, they cannot be accessed. (Only instructions MOVW A, PS and MOVW PS, A access the program status register.) #### Note: For details on how to use the dedicated register, see the $F^2MC-8L$ MB89600 Series Programming Manual. # 3.2.1 Condition Code Register (CCR) The condition code register (CCR) is the lower 8 bits of the program status register (PS). The condition code register consists of bits (C, V, Z, N, and H) for indicating the results of arithmetic operations or data to be transferred and control bits (I, IL1, and IL0) for controlling the acceptance of interrupt requests. ## ■ Configuration of the Condition Code Register (CCR) Figure 3.2-2 Configuration of Condition Code Register ## ■ Bits for Indicating Arithmetic Operation Results ## Half carry flag (H) When a carry from bit3 to bit4 or a borrow from bit4 to bit3 occurs as a result of an arithmetic operation, the half carry flag is set to "1". Otherwise, the half carry flag is cleared with "0". The half carry flag is intended only for decimal adjustment instructions, and thus should not be used for operations other than addition or subtraction. #### Negative flag (N) When the highest bit becomes "1" as a result of an arithmetic operation, the negative flag is set to "1". When it becomes "0", it is cleared with "0". ## Zero flag (Z) When the result of an arithmetic operation is "0", the zero flag is set to "1". Otherwise, the zero flag is cleared with "0". ## Overflow flag (V) When a complement on 2 overflow occurs as a result of an arithmetic operation, the overflow flag is set to "1". Otherwise, the overflow flag is cleared with "0". ## Carry flag (C) When a carry from bit7 or a borrow to bit7 occurs as a result of an arithmetic operation, the carry flag is set to "1". Otherwise, the carry flag is cleared with "0". The shift instruction causes the value to be shifted out. Figure 3.2-3 shows how the shift commands change the carry flag. Figure 3.2-3 Change of the Carrier Flag by the Shift Commands #### Note: The condition code register is part of the program status register (PS), and thus is not allowed to access only the condition code register. It is uncommon to fetch and use only some of the flag bits directly. Normally, branch instructions (such as BNZ) or decimal adjustment instructions (such as DAA and DAS) use them indirectly. The initial values of these flags specified after the reset operation are undefined. ## ■ Bits for Controlling Acceptance of Interrupts ## • Interrupt enable flag (I) When this flag is "1", interrupts are allowed and the CPU accepts interrupts. When this flag is "0", interrupts are prohibited and the CPU does not accept interrupts. The initial value of the interrupt enable flag after the reset operation is "0". Normally, the SETI instruction sets the interrupt enable flag to "1", and the CLRI instruction sets it to "0" to clear. ## Interrupt level bits (IL1 and IL0) These bits indicate the level of an interrupt the CPU is accepting, then it is compared with the values in the interrupt level setting registers (ILR1 to 4) which is specified as the level of interrupt requests of peripheral functions (IRQ0 to IRQF). When the interrupt enable flag is turned on (I=1), and if an interrupt is requested with an interrupt level value lower than that of these bits, the CPU accepts the interrupt. Table 3.2-1 provides interrupt level intensities. The initial value of the interrupt level specified after the reset operation is $11_B$ . Table 3.2-1 Interrupt Levels | IL1 | ILO | Interrupt level | Intensity | |-----|-----|-----------------|-----------------------------| | 0 | 0 | 1 | High | | 0 | 1 | 1 | <b>↑</b> | | 1 | 0 | 2 | ↓ | | 1 | 1 | 3 | Low (no interrupts allowed) | #### Note: When the CPU is not handling an interrupt (handling the main program), the interrupt level bits (IL1 and IL0) are normally set to $11_B$ . For details on interrupts, see Section "3.4 Interrupts ". # 3.2.2 Register Bank Pointer (RP) The register bank pointer (RP) is the upper 8 bits of the program status register (PS). The register bank pointer indicates the general-purpose register bank address being used, and the address is converted to the actual address in general-purpose register addressing. ## ■ Configuration of the Register Bank Pointer (RP) Figure 3.2-4 shows the configuration of the register bank pointer. Figure 3.2-4 Configuration of Register Bank Pointer The register bank pointer indicates the address of the register bank being used. Figure 3.2-5 shows the rule of conversion from the register bank pointer bits to the actual address. Figure 3.2-5 Rule of Conversion from the RP Bits to the Actual Address The register bank pointer specifies a memory block (register bank) used as a general-purpose register in the RAM area. There are 32 register banks. Setting a value (from 0 to 31) in the upper five bits of the register bank pointer specifies a register bank. One register bank contains eight 8-bit general-purpose registers that are selected with the lower 3 bits of an operation code. The register bank pointer allows a range of $0100_{\rm H}$ to $01{\rm FF_H}$ (maximum) to be used as the general-purpose register area. However, some models restrict the usable range when only internal RAM is used. The initial value of the register bank pointer specified after the reset operation is undefined. #### Note: Be sure to set up the register bank pointer (RP) before using general-purpose registers. The register bank pointer is part of the program status register (PS), and thus is not allowed to access only the register bank pointer. # 3.3 General-Purpose Registers The general-purpose registers are memory blocks. Eight 8-bits comprise a bank. The register bank pointer (RP) specifies a register bank. Although up to 32 banks can be used, some banks can be expanded onto external RAM if the capacity of internal RAM is not sufficient for all 32 banks. The general-purpose registers are effective for processing interrupts, vector calls, or subroutine calls. ## **■** Configuration of the General-purpose Registers - Each general-purpose register consists of 8 bits. The general-purpose registers are placed in the register banks at the general-purpose register area (on RAM). - One bank contains eight registers (R0 to R7), and up to 32 banks can be used. However, some models restrict the number of usable banks when only internal RAM is used. - The register bank pointer (RP) specifies the register bank being used. The lower three bits of an operation code indicate general-purpose register 0 (R0) to general-purpose register 7 (R7). Figure 3.3-1 shows the configuration of the register banks. 100<sub>H</sub>\* R<sub>0</sub> 000 R1 001 R2 010 R3 011 Bank 0 R4 100 (RP=00000---B) R5 101 R6 110 R7 111 108<sub>H</sub>\* R<sub>0</sub> 000 32 banks (on the RAM area) R1 001 Bank 1 The number of usable banks ÷ (RP=00001---B) is dependent on the size R7 of the usable RAM area. 111 Bank 2 to Bank 30 1F8<sub>H</sub>\* R0 000 Ban 31 : (RP=11111---B) R7 111 1FF<sub>H</sub>\* \*: Address at the top of the register banks = $0100_H + 8 \times (upper 5 \text{ bits of RP})$ Figure 3.3-1 Configuration of Register Bank For details on the general-purpose register area on each model, see Section "3.1.1 Specific-purpose Areas ". ## **■** Features of the General-purpose Registers The general-purpose registers have the following features: - High-speed access with short instructions (general-purpose register addressing) - Register banks (in blocks) that allow data to be easily conserved and partitioned in the unit of function The general-purpose registers allow specific register banks to be statically assigned with the interrupt processing routine or vector call (CALLV #0 to #7) processing routine. For example, it can be used such that the fourth register bank is always used for the second interrupt. For interrupts, unless data in a specific register bank that corresponds to an interrupt processing is incorrectly overwritten by another routine, simply specifying the specific register bank at the beginning of the interrupt processing routine stores the data contained in the general-purpose registers before interruption. This feature allows data in general-purpose registers to avoid being put in the stack and allows interrupts to be handled efficiently at high speed. For subroutine calls, in addition to conservation of data in general-purpose registers, the register banks can implement re-entrant programs (reloadable programs with variable addresses unfixed) that are usually created using the index register (IX) or another function. #### Note: A program must be created so that the values of the interrupt level bits in the condition code register (CCR: IL1 and IL0) do not change when the register bank pointer (RP) is rewritten to specify a register bank in the interrupt processing routine. # 3.4 Interrupts The MB89202/F202RA series supports 12 interrupt request inputs corresponding to peripheral functions and allows an interrupt level to be assigned to each of the inputs. The interrupt controller compares levels of interrupts generated by peripheral functions when output of interrupt requests is allowed for peripheral functions. The CPU performs the interrupt operation according to its interrupt acceptance settings. The CPU cancels standby mode on reception of an interrupt request, then returns to the interrupt operation or normal operation. ## ■ Interrupt Requests from Peripheral Functions Table 3.4-1 lists the interrupt requests that correspond to peripheral functions. When the CPU accepts an interrupt, the CPU takes a branch to the interrupt processing routine using the address in the interrupt vector table corresponding to the interrupt request as the branch address. The interrupt level setting registers (ILR1, 2, 3, and 4) allow one of four interrupt processing intensities to be assigned to each interrupt request. Interrupt requests with levels equal to or less than that of an interrupt request being handled in the interrupt processing routine are usually handled after the current interrupt processing routine ends. If interrupt requests with the same assigned level are generated simultaneously, IRQ0 has priority. Table 3.4-1 Interrupt Requests and Interrupt Vectors (1/2) | Interrupt request | Address in the vector table | | Names of bits in the interrupt | Priority at identical level (at | | |-------------------------------------------------|-----------------------------|-------------------|--------------------------------|---------------------------------|--| | mierrupt request | Upper<br>digits | Lower<br>digits | level setting registers | simultaneous<br>occurrence) | | | IRQ0 (External interrupt INT10) | FFFA <sub>H</sub> | FFFB <sub>H</sub> | L01, L00 | High | | | IRQ1 (External interrupt INT11) | FFF8 <sub>H</sub> | FFF9 <sub>H</sub> | L11, L10 | <b>A</b> | | | IRQ2 (External interrupt INT12) | FFF6 <sub>H</sub> | FFF7 <sub>H</sub> | L21, L20 | | | | IRQ3 (8/16-bit capture timer/counter's timer) | FFF4 <sub>H</sub> | FFF5 <sub>H</sub> | L31, L30 | | | | IRQ4 (8/16-bit capture timer/counter's capture) | FFF2 <sub>H</sub> | FFF3 <sub>H</sub> | L41, L40 | | | | IRQ5 (Transmission with UART) | FFF0 <sub>H</sub> | FFF1 <sub>H</sub> | L51, L50 | | | | IRQ6 (Reception with UART) | FFEE <sub>H</sub> | FFEF <sub>H</sub> | L61, L60 | | | | IRQ7 (Time-base timer) | FFEC <sub>H</sub> | FFED <sub>H</sub> | L71, L70 | | | | IRQ8 (A/D converter) | FFEA <sub>H</sub> | FFEB <sub>H</sub> | L81, L80 | | | | IRQ9 (8-bit PWM) | FFE8 <sub>H</sub> | FFE9 <sub>H</sub> | L91, L90 | ▼ | | | IRQA (External interrupt 2) | FFE6 <sub>H</sub> | FFE7 <sub>H</sub> | LA1, LA0 | Low | | Table 3.4-1 Interrupt Requests and Interrupt Vectors (2/2) | Interrupt request | Address in the vector table | | Names of bits in the interrupt | Priority at identical level (at | |-------------------------|-----------------------------|-------------------|--------------------------------|---------------------------------| | interrupt request | Upper<br>digits | Lower<br>digits | level setting registers | simultaneous<br>occurrence) | | IRQB (Flash interface) | FFE4 <sub>H</sub> | FFE5 <sub>H</sub> | LB1, LB0 | High | | IRQC (8-bit serial I/O) | FFE2 <sub>H</sub> | FFE3 <sub>H</sub> | LC1, LC0 | <b>A</b> | | IRQD (Unused) | FFE0 <sub>H</sub> | FFE1 <sub>H</sub> | LD1, LD0 | | | IRQE (Unused) | FFDE <sub>H</sub> | FFDF <sub>H</sub> | LE1, LE0 | ₩ | | IRQF (Unused) | FFDC <sub>H</sub> | FFDD <sub>H</sub> | LF1, LF0 | Low | # 3.4.1 Interrupt Level Setting Registers (ILR1 to ILR4) For the interrupt level setting registers (ILR1, 2, 3, and 4), 16 two-bit data items corresponding to interrupt requests sent from peripheral functions are assigned. Interrupt levels can be specified in these 2-bits (interrupt level setting bits). ## ■ Configuration of the Interrupt Level Setting Registers (ILR1 to ILR4) Register Address bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 (Initial value) L00 ILR1 007BH L31 L30 L21 L20 L11 L10 L01 1111 1111B (W) (W) (W) (W) (W) (W) (W) (W) ILR2 007CH L71 L70 L61 L60 L51 L50 L41 L40 1111 1111B (W) (W) (W) (W) (W) (W) (W) (W) ILR3 LB1 LB0 LA1 LA0 L91 L90 L81 L80 007DH 1111 1111B (W) (W) (W) (W) (W) (W) (W) (W) ILR4 007EH LF1 LF0 LE1 LE0 LD1 LD0 LC1 LC0 1111 1111B (W) (W) (W) (W) (W) (W) (W) (W) W: Write only Figure 3.4-1 Configuration of Interrupt Level Setting Register For each interrupt request, 2 bits of the interrupt level setting registers are assigned. The values specified in the interrupt level setting registers are the intensities for processing the interrupts (interrupt levels 1 to 3). Interrupt level setting bits are compared with interrupt level bits in the condition code register (CCR: IL1 and IL0). When interrupt level 3 is specified, the CPU does not accept interrupt requests. Table 3.4-2 provides the relationship between interrupt level setting bits and interrupt levels. Table 3.4-2 Relationship between Interrupt Level Setting Bits and Interrupt Levels | L01 to LF1 | L00 to LF0 | Requested interrupt level | Priority | |------------|------------|---------------------------|--------------------| | 0 | 0 | 1 | High | | 0 | 1 | 1 | <b>^</b> | | 1 | 0 | 2 | ₩ | | 1 | 1 | 3 | Low (no interrupt) | #### **Notes:** - When the main program is being executed, the interrupt level bits in the condition code register (CCR: IL1 and IL0) are normally set to 11<sub>B</sub>. - The ILR1 to ILR4 registers are write-only enabled, and thus the bit manipulation instructions (SETB and CLRB) cannot be used. # 3.4.2 Steps in the Interrupt Operation When an interrupt request is generated in a peripheral function, the interrupt controller notifies the CPU of its interrupt level. If the CPU can accept an interrupt, the CPU temporarily stops the program that is handling and starts the interrupt processing routine. ## ■ Steps in the Interrupt Operation The steps for processing an interrupt are: occurrence of a source of an interrupt in a peripheral function, designation of the interrupt request flag bit (request F/F), check on the interrupt request enable bit (enable F/F), check on the interrupt level (ILR1, 2, 3, or 4, and CCR: IL1 and IL0), check on another request with the same level, and check on the interrupt enable flag (CCR: I). Figure 3.4-2 shows the steps in the interrupt operation. Figure 3.4-2 Steps in the Interrupt Operation - ① After a reset, all interrupt requests are prohibited. - Initialize the peripheral functions that generate interrupts using a initialization program for peripheral functions, specify interrupt levels in the interrupt level setting registers (ILR1 to ILR4) concerned, then start up the peripheral functions. - Interrupt levels 1, 2, and 3 can be specified. Level 1 is the highest level, and level 2 is the second highest level. Level 3 prohibits interrupts from the peripheral functions to which it is assigned. - 2 Run the main program. (For a multiple-interrupt, run the interrupt processing routine.) - ③ When a peripheral function generates a source of an interrupt, the interrupt request flag bit for peripheral function (request F/F) is set to "1". If the interrupt request enable bit for a peripheral function is turned on (enable F/F = 1) at that time, an interrupt request is output to the interrupt controller. - The interrupt controller is always monitoring interrupt requests from peripheral functions. The interrupt controller notifies the CPU of the highest interrupt level interrupt among levels corresponding to interrupt requests currently generated. If different requests are made with the same interrupt level, the interrupt controller also determines their priorities. - (5) The CPU checks the value in the interrupt enable flag (CCR: I) when the priority of the interrupt level that is received is higher (the level value is lower) than the level specified in the interrupt level bits in the condition code register (CCR: IL1 and IL0). The CPU then accepts the interrupt when the enable flag is turned on (CCR: I = 1). - © Put the values in the program counter (PC) and program status (PS) in the stack, fetch the start address of the interrupt processing routine from the interrupt vector table concerned, change the value of the interrupt level bits in the condition code register (CCR: IL1 and IL0) to the value of the interrupt level accepted, and then start the interrupt processing routine. - Tinally, restore the values of the program counter (PC) and program status (PS) put into the stack with the RETI instruction, then execute an instruction following the instruction executed immediately before the interruption. Standby mode (low-power consumption mode) is cancelled by an interrupt. For details, see Section "3.7 Standby Mode (Low-Power Consumption Mode)". #### **Notes:** - An interrupt request flag bit for a peripheral function is not automatically cleared even if the interrupt request is accepted. Therefore, it is necessary to clear the bit using a program in the interrupt processing routine (by writing "0" into the interrupt request flag bit normally). - Clearing an interrupt request flag bit at the beginning of the interrupt processing routine allows the peripheral function that generated the interrupt to re-generate an interrupt (set an interrupt request flag bit again) while the interrupt processing routine is being executed. However, the re-generated interrupt is normally accepted after the interrupt processing routine ends its current cycle. # 3.4.3 Multiple Interrupts Multiple interrupts are allowed by setting different levels into the interrupt level setting registers (ILR1 to ILR4) for multiple interrupt requests from peripheral functions. ## **■** Multiple Interrupts When an interrupt request with a higher interrupt level is generated while the interrupt processing routine is operating, the current interrupt processing cycle is stopped to accept the higher-level interrupt request. Interrupt levels 1, 2, and 3 can be specified. Level 3 prohibits the CPU from accepting interrupts. #### Example of multiple interrupts As an example of multiple-interrupt processing, suppose a case in which a timer interrupt has precedence using the A/D interrupt, and the A/D interrupt level is set to level 2 and the timer interrupt level is set to level 1. Figure 3.4-3 shows the sequence performed when an external interrupt is generated while an A/D interrupt is being processed. Figure 3.4-3 Example of Multiple Interrupts - In the A/D interrupt processing, the interrupt level bits in the condition code register (CCR: IL1 and IL0) are set to the same value as the value in the interrupt level setting register corresponding to the A/D interrupt (ILR1, 2, 3, or 4) (i.e., 2 in this example). If an interrupt request with a higher interrupt level specified is generated (1 in this example), processing for the higher interrupt level is effected first. - To temporarily prohibit multiple interrupts in the A/D interrupt processing, turn off the interrupt enable flag (CCR: I = 0) in the condition code register, or set 00<sub>R</sub> to the interrupt level bits (IL1 and IL0). - Executing the return instruction (RETI) after interrupt processing restores the values of the program counter (PC) and program status (PS) and ensures resumption of the interrupted program. - The value in the condition code register (CCR) is returned to the value used before interruption when the program status (PS) value is restored. # 3.4.4 Interrupt Processing Time From when an interrupt request is generated to when control is transferred to the interrupt processing routine, both the time to quit the instruction being executed and the time to manage the interrupt (required to prepare interrupt processing) are required. The total time must be within 30 instruction cycles. ## ■ Interrupt Processing Time From when an interrupt request is generated and accepted to when the interrupt processing routine starts, sufficient time is required to wait for an interrupt request sample and to manage the interrupt. #### Interrupt request sample wait time Generation of an interrupt request is checked by sampling an interrupt request at the last cycle of each instruction. Therefore, the CPU cannot identify an interrupt request while it is executing an instruction. The wait time becomes maximum when an interrupt request is generated immediately after the CPU executes the DIVU instruction (21 instruction cycles) with the longest instruction cycle. #### Interrupt handling time After accepting an interrupt, the CPU needs 9 instruction cycles for interrupt processing preparation to: - Save the values in the program counter (PC) and program status (PS) - Set the address at the beginning of the interrupt processing routine (interrupt vector) into the PC - Update the interrupt level bits (PS: CCR: IL1 and IL0) in the program status (PS). Figure 3.4-4 shows the interrupt processing time. CPU performs → Execution of general instruction Interrupt handling routine Interrupt wait time Interrupt handling time (9 instruction cycles) Interrupt request sample wait time Interrupt handling time (9 instruction cycles) Figure 3.4-4 Interrupt Processing Time When an interrupt request is generated immediately after the DIVU instruction having the longest instruction cycle (21 instruction cycles), 30 instruction cycles (21 instructions + 9 instructions) are required for the interrupt processing time. However, if the DIVU instruction and MULU instruction are not used in the program, a maximum of 15 (6 instructions + 9 instructions) instructions are required for the instruction processing time. An instruction cycle is changed by clock speed switching (gears). For details, see Section "3.6 Clock ". # 3.4.5 Stack Operation at Interrupt Processing This section describes how values in registers are saved and restored at interrupt processing. ## ■ Stack Operation at the Beginning of Interrupt Processing After accepting an interrupt, the CPU automatically saves the values in the program counter (PC) and program status (PS) in the stack. Figure 3.4-5 shows the stack operation at the beginning of interrupt processing. Immediately before Immediately after interruption interruption Address Memory Address Memory 027Сн 08<sub>H</sub> 027CH 027CH XXH0870н PS 027D<sub>H</sub> 70<sub>H</sub> 027D<sub>H</sub> XXH027E<sub>H</sub> E<sub>0</sub><sub>H</sub> 027E<sub>H</sub> Е000н 0870<sub>H</sub> PC 027F<sub>H</sub> 00<sub>H</sub> 027F<sub>H</sub> XXH $XX_H$ 0280н 0280<sub>H</sub> XX<sub>H</sub> 0280H E000<sub>H</sub> 0281<sub>H</sub> $XX_H$ 0281н XXH Figure 3.4-5 Stack Operation at the Beginning of Interrupt Processing ## ■ Stack Operation at the End of Interrupt Processing When the return instruction (RETI) is executed at the end of interrupt processing, the values in the program status (PS) and the program counter (PC) are restored from the stack in that order (which is opposite to that at the beginning of interrupt processing). This operation restores the values in the PS and PC to those values used before interruption. #### Note: Values in the accumulator (A) and temporary accumulator (T) are not automatically saved in the stack. Therefore, save and restore the values using the PUSHW and POPW instructions. # 3.4.6 Stack Area for Interrupt Processing A stack area on RAM is used for interrupt processing. The value in the stack pointer (SP) is used as the start address of the stack area. ## ■ Stack Area for Interrupt Processing The stack area is used to save/restore the value in the program counter (PC) when executing the subroutine call instruction (CALL) or vector call instruction (CALLV) or temporarily save and restore values in registers or other storage with the PUSHW and POPW instruction. - Locate the stack area on RAM together with the data area. - It is recommended that the initial settings be specified such that the stack pointer (SP) indicates the highest address of RAM and that the data area be set up from the lowest address of RAM. Figure 3.4-6 is an example showing the stack area. Figure 3.4-6 Stack Area for Interrupt Processing #### Note: For the stack area, interrupts, subroutine calls, or PUSHW instruction use addresses in descending order, and the return instructions (RETI and RET) or the POPW instruction releases addresses in the stack area in ascending order. When a lower address is used in the stack area due to multiple interrupts or subroutine calls, make arrangements so that the stack area does not overlap with the data area and general-purpose register area containing other data. ## 3.5 Reset ## There are four sources of reset: - External reset - Software reset - · Watchdog reset - · Power-on reset Oscillation stabilization wait time is not applied in some operating modes when a reset occurs or in some option settings. #### ■ Reset Sources Table 3.5-1 Reset Sources | Reset source | Reset condition | |----------------|-----------------------------------------------------------------------------------------| | External reset | The external reset pin is "L" level. | | Software reset | "0" is written into the software reset bit in the standby control register (STBC: RST). | | Watchdog reset | The watchdog timer overflows. | | Power-on reset | Power is turned on. | #### External reset External reset occurs when "L" level is input to the external reset pin $(\overline{RST})$ . When the reset pin becomes "H" level, the external reset is cancelled. For external reset when power is turned on or in stop mode, the reset operation is performed after oscillation stabilization wait time is up or the external reset is cancelled. The external reset pin functions as the reset output pin in accordance with option settings. #### Software reset Software reset generates a 4-instruction cycle reset by writing "0" into the software reset bit in the standby control register (STBC: RST). Software reset does not wait until oscillation stabilization wait time has expired. #### Watchdog reset Watchdog reset generates a 4-instruction cycle reset when no data is written into the watchdog control register (WDTC) within a specified time after the watchdog timer is activated. Watchdog reset does not wait until oscillation stabilization wait time is up. #### Power-on reset Power-on reset occurs when power is turned on. Power-on reset occurs after oscillation stabilization wait time has expired. Power-on reset requires an external reset circuit. ## ■ Reset Sources and Oscillation Stabilization Wait Time Operations in oscillation stabilization wait time depend on the operating mode used when a reset occurs. After a reset, active mode is set regardless of the operating mode applied before the reset (standby mode) and reset source. Therefore, if a reset occurs while oscillation is being stopped or within the oscillation stabilization wait time, the oscillation stabilization wait reset mode is set. Software reset and watchdog reset do not apply oscillation stabilization wait time. Table 3.5-2 shows the relationship between reset sources, oscillation stabilization wait time, and the reset operation (mode fetch). Table 3.5-2 Relationship between the Reset Sources and Oscillation Stabilization Wait Time | Reset source | Operating mode | Reset operation and oscillation stabilization wait time | |-----------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | External reset* | When power is<br>turned on or stop<br>mode | The reset operation is performed when external reset is cancelled after oscillation stabilization wait time has expired. | | Software reset and watchdog reset | Active mode | The reset operation is performed following the generation of a 4-instruction cycle reset. | | Power-on reset | When power is turned on | The reset operation is performed after power is turned on and oscillation stabilization wait time has expired. | <sup>\*</sup> External reset in active mode does not apply oscillation stabilization wait time. The reset operation is performed after cancellation of external reset. # 3.5.1 Reset Flag Register (RSFR) The reset flag register (RSFR) allows confirmation of the source for a generated reset. ■ Configuration of the Reset Flag Register (RSFR) Figure 3.5-1 Configuration of Reset Flag Register (RSFR) Table 3.5-3 Explanation of Functions of Each Bit in the Reset Flag Register (RSFR) | | Bit name | Description | |--------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | PONR:<br>Power-on reset flag<br>bit | "1" is set to this bit when power-on reset occurs. "1" is set to this bit after power is turned on. This bit is cleared with "0" after being read. Writing a value to this bit has no significance. | | bit6 | ERST:<br>External reset flag bit | "1" is set to this bit when external reset occurs. "1" is set to this bit while other reset flags are maintained when all other reset flags have been set before the external reset flag is set. This bit is cleared with "0" after being read. Writing a value to this bit has no significance. | | bit5 | WDOG:<br>Watchdog reset flag<br>bit | "1" is set to this bit when watchdog reset occurs. "1" is set to this bit while other reset flags are maintained when all other reset flags have been set before the watchdog reset flag is set. This bit is cleared with "0" after being read. Writing a value to this bit has no significance. | | bit4 | SFTR:<br>Software reset flag<br>bit | "1" is set to this bit when software reset occurs. "1" is set to this bit while other reset flags are maintained when all other reset flags have been set before the software reset flag is set. This bit is cleared with "0" after being read. Writing a value to this bit has no significance. | | bit3<br>to<br>bit0 | Unused bits | The values read out are undefined. Writing data to these bits does not affect operations. | ## Note: A reset source flag is set when a reset source is generated. When the reset source flag register is read, all bits in the reset source flag register are cleared. Therefore, to determine the source of a reset, read this register using the initial value setting routine after the reset. ## 3.5.2 External Reset Pin The external reset pin generates a reset by "L" level input. When an option setting for enabling reset output is selected, the "L" level signal is output depending on the internal reset source. ## ■ Block Diagram of External Reset Pin The external reset pin $(\overline{RST})$ on models with supported reset output has hysteresis input and pull-up N-ch open drain output. The external reset pin on models without supported reset output is used only as the pin dedicated to reset input. Figure 3.5-2 is a block diagram of the external reset pin. $\begin{array}{c|c} \text{Pull-up resistor} \\ \text{Approx. } 50 \text{k}\Omega \text{ for } 5 \text{ V} \\ \text{(Not available for MB89F202)} \\ \hline \\ \text{Pin} \\ \hline \\ \text{RST} \\ \hline \\ \text{N-ch} \\ \hline \end{array}$ Figure 3.5-2 Block Diagram of External Reset Pin ## **■** Function of the External Reset Pin The external reset pin (RST) generates an internal reset signal by making use of "L" level input. The $\overline{RST}$ outputs the "L" level signal according to the internal reset source and oscillation stabilization wait time applied following a reset. The internal reset source may be software reset, watchdog reset, or power-on reset. #### Note: External reset input is accepted asynchronously regardless of the internal clock. Initialization of the internal circuits requires a clock. In particular, for operations with an external clock, the clock must be input when a reset signal is input. Internal pull-up control for $\overline{RST}$ is not available for MB89F202/F202RA. To ensure proper external reset control in MB89F202/F202RA, an external pull-up (recommend 100 k $\Omega$ ) for $\overline{RST}$ pin must be required. # 3.5.3 Reset Operation The CPU reads the mode data (mode fetch) and reset vector from internal ROM according to the mode pin settings following the cancellation of a reset. For a return triggered by a reset when power is turned on and in stop mode, the CPU fetches the mode after oscillation stabilization wait time has expired. When a reset occurs, the contents in RAM cannot be guaranteed. ## ■ Overview of the Reset Operation Figure 3.5-3 Reset Operation Flow ## **■ Mode Fetch** The CPU reads the mode data and reset vector from internal ROM following the cancellation of the reset. ■ Mode data (address: FFFD<sub>H</sub>) Set single-chip mode (00<sub>H</sub>) to the mode data. Reset vector (address: FFFE<sub>H</sub> (highest)/FFFF<sub>H</sub> (lowest)) Specify the address at which execution is to be started after the reset operation is completed. The CPU starts executing instructions from the specified address. ## State of Reset Waiting for Stabilization of Oscillation The CPU performs a reset operation for a reset when power is turned on or an external reset in stop mode when the oscillation stabilization wait time specified with option settings has expired. In this case, if the external reset input is not cancelled, the CPU performs the reset operation following cancellation of the external reset. When an external clock is used, oscillation stabilization wait time is applied, and thus input of an external clock is required at a reset. The time-base timer generates oscillation stabilization wait time. ## ■ Influence from a Reset of Contents in RAM When reset conditions occur, the CPU stops handling the current instruction, then enters the reset state. The contents in RAM does not change even after a reset. However, if a reset occurs while 16-bit data is being written, the upper byte (only) is written; the lower byte may be unwritten. If a reset occurs immediately after, immediately before, or while data is written, the contents in the address to which data is written at that time is not guaranteed. # 3.5.4 State of Each Pin at Reset ## The state of each pin is initialized by a reset. ## ■ States of Pins during Reset When a reset occurs, most I/O pins (resource pins) become Hi-Z, and the CPU reads the mode data from internal ROM. ## ■ States of Pins after the CPU Reads the Mode Data Most of the I/O pins remain Hi-Z immediately after the CPU reads the mode data. For pin states established by something other than a reset, see "APPENDIX E Pin State of the MB89202/F202RA Series" for details. #### Note: For pins that are Hi-Z when a reset source is generated, set up the devices connected with the pins such that they do not malfunction. ## 3.6 Clock The clock generator includes the oscillation circuit. A high-speed clock is generated by connecting an external resonator for oscillation frequency. Alternatively, when the clock is supplied from an external source, a clock signal can be connected to the clock input pin. The clock controller manages the speed and supply of the clock in active mode and standby mode. ## ■ Clock Supply Map The clock controller manages oscillation of the clock and provision of the clock to the CPU and peripheral circuits (peripheral functions). Thus, the operating clock for the CPU or peripheral circuits is affected by clock speed switching (gears) and setting in standby mode (sleep/stop). To peripheral functions, a divided frequency output of the free-run counter operating with the clock for peripheral circuits is provided. However, the divided frequency output of the time-base timer operating with 1/2 frequency of the oscillation frequency is not affected by the gear. Figure 3.6-1 shows the clock supply map. Figure 3.6-1 Clock Supply Map # 3.6.1 Clock Generator The clock generator enables oscillation in active mode and disables oscillation in stop mode. ## **■ Clock Generator** For a crystal resonator or ceramic resonator Connect it as shown in Figure 3.6-2. Figure 3.6-2 Example of Connecting a Crystal Resonator or Ceramic Resonator For an external clock Connect it to the X0 pin and open the X1 pin as shown in Figure 3.6-3. Figure 3.6-3 Example of Connecting an External Clock ## 3.6.2 Clock Controller The clock controller consists of the following six blocks: - Oscillation circuit - System clock selector - Clock controller - · Oscillation stabilization wait time selector - System clock control register (SYCC) - Standby control register (STBC) ## ■ Block Diagram of Clock Controller Figure 3.6-4 is a block diagram of the clock controller. Figure 3.6-4 Block Diagram of Clock Controller #### Oscillator Oscillation circuit that halts oscillation in stop mode. ## System clock selector Selects one of four frequency-divided source clocks to be supplied to the clock control circuit. #### Clock controller Controls the operating clock supplied to the CPU and peripheral circuits according to the active (RUN) mode and standby mode (sleep, stop). It also stops supply of the clock to the CPU until the clock supply stop signal for the oscillation stabilization wait time selector is cancelled. #### Oscillation stabilization wait time selector Selects one of three oscillation stabilization wait time periods generated by the time-base timer according to the standby mode or a reset, then outputs the clock supply stop signal to the CPU by using the selected time period. ## System clock control register (SYCC) Selects the clock speed and oscillation stabilization wait time setting, then checks the clock state. ## Standby control register (STBC) Controls transition from active (RUN) mode to standby mode, pin state settings at stop mode, and software reset. #### 3.6.3 System Clock Control Register (SYCC) The system clock control register (SYCC) manages clock settings such as selection of the clock speed and oscillation stabilization wait time. ## ■ Configuration of the System Clock Control Register (SYCC) bit4 bit3 bit1 bit0 Initial value SCM WT1 WT0 CS1 CS0 1--MM-00<sub>B</sub> R/W R/W R/W R R/W Figure 3.6-5 Configuration of System Clock Control Register (SYCC) Address bit7 0007н Clock speed selection bits CS1 CS<sub>0</sub> Instruction cycle (when F<sub>CH</sub> is 12.5 MHz) 0 0 64/F<sub>CH</sub> (5.12 μs) 0 16/F<sub>CH</sub> (1.28 μs) 8/F<sub>CH</sub> (0.64 μs) 1 $4/F_{CH}$ (0.32 µs) Oscillation stabilization wait time selection bits WT1 WT0 Oscillation stabilization wait time according to output of the time-base timer (when FcH is 12.5 MHz) 0 Setting prohibited 1 Approx. 214/FCH (approx. 1.31 ms) 0 Approx. 217/F<sub>CH</sub> (approx. 10.5 ms) 1 Approx. 218/FCH (approx. 21.0 ms) 1 SCM System clock monitor bit Clock stopping or waiting for stabilization of oscillation Active mode R/W: Readable/Writable Read only Unused M: Mask option : Initial value Table 3.6-1 Explanation of Functions of Each Bit in the System Clock Control Register (SYCC) | | Bit name | Description | |---------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | SCM: System clock<br>monitor bit | Used to check the current clock mode. When this bit is 0, the clock is stopping or waiting for stabilization of oscillation. When this bit is 1, operations are performed in active mode. Note: This bit is read-only enabled. Writing a value to this bit does not affect operation. | | bit6,<br>bit5 | Unused bits | Values in these bits are undefined when read. Writing values into these bits does not affect operation. | | bit4,<br>bit3 | WT1, WT0:<br>Oscillation<br>stabilization wait time<br>selection bits | Used to select an oscillation stabilization wait time setting. When external interrupt causes a return from stop mode to active mode, the oscillation stabilization wait time setting selected by these bits is applied. The initial values of these bits are determined by options. Therefore, when an oscillation stabilization wait time setting is to be applied for a reset, it is selected by options. Note: Change values in these bits after confirming that the clock is not waiting for stabilization of oscillation using the SCM bit. | | bit2 | Unused bit | This bit is always "1" when read. Note: Specify "1". | | bit1,<br>bit0 | CS1, CS0:<br>Clock speed selection<br>bits | Used to select the clock speed in active mode. One of four operating clock speeds (gears) can be specified for the CPU and peripheral functions. However, these bits do not affect the operating clock for the time-base timer. | # ■ Instruction Cycle (t<sub>INST</sub>) For instruction cycles (minimum instruction run time), a 1/4, 1/8, 1/16, or 1/64 frequency can be selected using the clock speed selection bits (CS1 and CS0). In active mode, when the oscillation frequency ( $F_{CH}$ ) is 12.5 MHz, the instruction cycle for the maximum speed (SYCC: CS1 and CS0 = 11<sub>B</sub>) is $4/F_{CH}$ (= about 0.32 $\mu$ s). # 3.6.4 Clock Mode The clock speed is switched by selecting one of four frequency-divided source clocks (gears). # ■ Operations in Each Clock Mode **Table 3.6-2 Operations in Each Clock Mode** | Clock speed | | | | Operatin | g clock in eac | Cause that cancels | | |-----------------------------------------|---------------|--------------------|---------------------|---------------------|--------------------|----------------------|-----------------------------------| | SYCC register<br>(SYCC: CS1<br>and CS0) | | Standby<br>mode | Clock | CPU | time-base<br>timer | Peripheral function | standby mode<br>(excepting reset) | | | High | RUN | Generated | F <sub>CH</sub> /4 | F <sub>CH</sub> /2 | F <sub>CH</sub> /4 | Interrupt request | | (1, 1) | speed | Sleep | Generated | Stopped | 1 CH/ 2 | 1 CH <sup>7</sup> 1 | | | | <b>A</b> | Stop | Stopped | stopped - | Stopped | Stopped | External interrupt | | | RUN Generated | F <sub>CH</sub> /8 | F <sub>CH</sub> /2 | F <sub>CH</sub> /8 | Interrupt request | | | | (1, 0) | | Sleep | Generated | Stopped | 1 CH <sup>2</sup> | 1 CH | | | | | Stop | top Stopped Stopped | Stopped | Stopped | Stopped | External interrupt | | | | RUN | Generated | F <sub>CH</sub> /16 | F <sub>CH</sub> /2 | F <sub>CH</sub> /16 | Interrupt request | | (0, 1) | | Sleep | Generated | Stopped | 1 CH <sup>2</sup> | T CH <sup>7</sup> TO | | | | | Stop | Stopped | Stopped | Stopped | Stopped | External interrupt | | | lacksquare | RUN | Generated | F <sub>CH</sub> /64 | F <sub>CH</sub> /2 | F <sub>CH</sub> /64 | Interrupt request | | (0, 0) | Low | Sleep | Generated | Stopped | T CH' 2 | · CH/O1 | | | | speed | Stop | Stopped | ыорреа | Stopped | Stopped | External interrupt | Each clock mode allows transition to a corresponding standby (sleep/stop) mode. For details of standby mode, see Section "3.7 Standby Mode (Low-Power Consumption Mode) ". # ■ Gears (Clock Speed Switching Function) Writing one of $00_B$ to $11_B$ into the clock speed selection bits (SYCC: CS1 and CS0) in the system clock control register selects one of four clock speeds. The CPU and peripheral circuits operate using the clock speed selected. However, the gear does not affect the time-base timer. Power consumption can be reduced by lowering the clock speed. # **■** Operations in Active Mode In active (RUN) mode, the oscillator is generating a clock. The CPU, time-base timer, and other peripheral circuits operate using the clock. In active mode, all clock speeds except the time-base timer clock speed can be changed (using gears). In active mode, specifying standby mode results in a transition to sleep mode or stop mode. Operations always start in RUN mode after a reset (any type). (Operating modes are cancelled by a reset.) #### Note: Do not rewrite the values in the oscillation stabilization wait time selection bits (SYCC: WT1 and WT0) while the clock is waiting for stabilization of oscillation. Using the system clock monitor bits, change the values in these bits after checking that SYCC: SCM is "1". # 3.6.5 Oscillation Stabilization Wait Time Oscillation stabilization wait time is to be applied when power is turned on to start the clock in RUN mode while the clock is stopped in stop mode. #### ■ Oscillation Stabilization Wait Time A ceramic or crystal resonator normally requires several or several tens of milli-seconds from oscillation start to oscillation stabilization at a specific cycle (oscillation frequency). Thus, CPU operation must be prohibited immediately after the start of oscillation, and the clock is to be supplied to the CPU when oscillation is stable following the expiration of oscillation stabilization wait time The period during which oscillation becomes stable is dependent on the type of oscillator (such as crystal or ceramic) connected to the oscillation circuit (clock generator). Therefore, an oscillation stabilization wait time setting appropriate to the oscillator used must be selected. Figure 3.6-6 shows changes in a frequency generated by an resonator from generation to stabilization. Figure 3.6-6 Changes of a Frequency after Generation #### ■ Oscillation Stabilization Wait Time Oscillation stabilization wait time is to be applied to start the clock in active mode while the clock is stopped. Oscillation stabilization wait time is the duration from when the counter of the time-base timer is cleared to when the specified bits overflow. #### Oscillation stabilization wait time during operation For oscillation stabilization wait time applied for a return from stop mode to active (RUN) mode due to external interrupt, one of three oscillation stabilization wait time settings can be selected using the oscillation stabilization wait time selection bits in the system clock control register (SYCC: WT1 and WT0). #### Oscillation stabilization wait time at a reset Option settings specify oscillation stabilization wait time at a reset (initial values of WT1 and WT0). Cancellation of stop mode by external reset also applies oscillation stabilization wait time. Table 3.6-3 shows the relationship between the active mode operation start conditions and oscillation stabilization wait time. Table 3.6-3 Active Mode Operation Start Conditions and Oscillation Stabilization Wait Time | Active mode operation start | When power is turned | Cancellation of stop mode | | | |--------------------------------------------------|----------------------|---------------------------|--------------------|--| | condition | on | External reset | External interrupt | | | Selection of oscillation stabilization wait time | Option sett | ings | SYCC: WT1, WT0 | | # 3.7 Standby Mode (Low-Power Consumption Mode) The MB89202/F202RA series supports sleep mode and stop mode in standby mode. Transition to standby mode is controlled by the standby control register (STBC) settings. In active mode, transition to sleep mode or stop mode is allowed. In standby mode, operation of the CPU and peripheral functions is stopped to reduce power consumption. This section describes the relationship between standby mode and clock mode and explains block operations in standby mode. #### ■ Standby Mode In active mode, power consumption is reduced by lowering the speed of the operating clock for the CPU and peripheral circuits using clock speed switching (gears). However, in standby mode, the clock controller stops supply of the clock to the CPU (sleep mode) or stops oscillation of the source (stop mode) to reduce power consumption. #### Sleep mode In sleep mode, the CPU and watchdog timer are stopped. Peripheral functions operate using the normal clock. # Stop mode In stop mode, the CPU and peripheral functions are stopped, and the clock does not oscillate. All the functions except for external interrupt halt. # 3.7.1 Operations in Standby Mode This section describes CPU and peripheral function operation in standby mode. # **■** Operations in Standby Mode Table 3.7-1 Operations of the CPU and Peripheral Functions in Standby Mode | | Function | RUN | Sleep | Stop<br>(SPL=0) | Stop<br>(SPL=1) | | |---------------------|--------------------------------|--------|---------------|-----------------|-----------------|--| | | Clock | Active | Active | Stopped | Stopped | | | | Instruction | Active | Stopped | Stopped | Stopped | | | CPU | ROM | Active | II a l d'in a | Halding. | Haldina | | | | RAM | Active | Holding | Holding | Holding | | | | I/O port | Active | Holding | Holding | Hi-Z | | | | Time-base timer | Active | Active | Stopped | Stopped | | | | Watchdog timer | Active | Stopped | Stopped | Stopped | | | | 8-bit PWM timer/counter | Active | Active | Stopped | Stopped | | | | 8/16-bit capture timer/counter | Active | Active | Stopped | Stopped | | | Peripheral function | UART | Active | Active | Stopped | Stopped | | | | 8-bit serial I/O | Active | Active | Stopped | Stopped | | | | 12-bit PPG | Active | Active | Active Stopped | | | | | Buzzer | Active | Active | Stopped | Stopped | | | | External interrupt 1 and 2 | Active | Active | Active | Active | | | | A/D converter | Active | Active | Stopped | Stopped | | ## State of pins in standby mode The state of most I/O pins can remain the same as those set immediately before transition to stop mode or set to Hi-Z using the pin state setting bit in the standby control register (STBC: SPL), regardless of clock mode. #### Note: For details on pin states in standby mode, see "APPENDIX E Pin State of the MB89202/F202RA Series". # 3.7.2 Sleep Mode ## This section describes sleep mode. # **■** Operations Relating to Sleep Mode #### Transition to sleep mode In sleep mode, the operating clock for CPU is stopped. Although the CPU stops storing data in the registers and RAM used immediately before transition to sleep mode, peripheral functions, excepting the watchdog timer, continue to operate. Writing "1" to the sleep bit in the standby control register (STBC: SLP) results in a transition to sleep mode. Any attempt to write "1" into the SLP bit while an interrupt request is being generated fails, transition to sleep mode cannot be made, and instructions are processed continuously. (Even after the interrupt is processed completely, transition to sleep mode is not possible.) #### Cancellation of sleep mode Sleep mode is cancelled by a reset or interrupt from a peripheral function. Pin states are initialized by the reset operation. When an interrupt request with an interrupt level higher than $11_B$ is generated in a peripheral function or external interrupt circuit in sleep mode, sleep mode is cancelled regardless of the CPU interrupt enable flag (CCR: I) or interrupt level bits (CCR: IL1 and IL0). When sleep mode is cancelled, a normal interrupt operation is performed, and if interrupts are acceptable, interrupt processing is performed. Otherwise, if interrupts are unacceptable, the processing resumes starting from an instruction next to the instruction which was issued immediately before transition to sleep mode. # **3.7.3 Stop Mode** # This section describes the stop mode. # ■ Operations Relating to Stop Mode #### Transition to stop mode In stop mode, the oscillation frequency is stopped. Most functions stop storing data in the registers and RAM used immediately before transition to stop mode. The clock circuit stops oscillating, the peripheral functions and CPU stop operating, but the external interrupt circuit continues to operate. Writing "1" to the stop bit in the standby control register (STBC: STP) causes a transition to stop mode. At that time, if the pin state setting bit (STBC: SPL) is "0", the states of the external pins are maintained. If the pin state setting bit is "1", the states of the external pins are set to Hi-Z (the states of pins for which a pull-up resistor is specified in the pull-up setting resistor are set to level "H"). An attempt to write "1" into the STP bit while an interrupt request is being generated fails, transition to stop mode cannot made, and instructions are processed continuously. (Even after the interrupt is processed completely, transition to stop mode is not made.) For a transition to stop mode, prohibit the time-base timer interrupt request output (TBTC: TBIE = 0) when necessary. #### Cancellation of stop mode Stop mode is cancelled by a reset or external interrupt. When a reset occurs in stop mode, the reset operation is performed after oscillation stabilization wait time. pin states are initialized by the reset operation. When an interrupt request with an interrupt level higher than $11_{\rm B}$ is generated in an external interrupt circuit in stop mode, stop mode is cancelled regardless of the CPU interrupt enable flag (CCR: I) or interrupt level bits (CCR: IL1 and IL0). When stop mode is cancelled and oscillation stabilization wait time has expired, a normal interrupt operation is performed. Then, if interrupts are acceptable, interrupt processing is performed. Otherwise, an instruction following the instruction immediately before transition to stop mode is managed. When an external interrupt cancels stop mode, part of the peripheral functions are restarted with data stored before the beginning of sleep mode. Therefore, the initial interval of the interval timer and other similar settings are rendered unknown. The peripheral functions must be initialized after returning from stop mode. #### Note: Among interrupts, only an interrupt request from the external interrupt circuit cancels the stop mode. # 3.7.4 Standby Control Register (STBC) The standby control register (STBC) controls transition to sleep /stop modes, pin state settings in stop mode, and software reset. # ■ Standby Control Register (STBC) : Unused: Initial value Address Initial value bit7 bit6 bit5 bit4 bit3 bit1 bit0 00010---B Н8000 STP SLP SPL RST RESV R/W R/W R/W R/W Reserved bit RESV When read When written 0 Always "0" Does not affect operations 1 Software reset bit **RST** When written When read 4-instruction reset signal 0 generated. 1 Does not affect operations Always "1" SPL Pin state setting bit Pin states applied are maintained in stop mode. 0 Pin states are set to Hi-Z in stop mode. Sleep bit SLP When written When read Always "0" Does not affect operations 0 1 Transition to sleep mode Stop bit STP When read When written Always "0" 0 Does not affect operations Transition to stop mode 1 R/W: Readable/Writable R : Read only Figure 3.7-1 Standby Control Register (STBC) Table 3.7-2 Explanation of Functions of Each Bit in the Standby Control Register (STBC) | E | Bit name | Description | |--------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | STP:<br>Stop bit | This bit specifies transition to stop mode. Writing "1" into this bit allows transition to stop mode. Writing "0" into this bit does not affect operations. This bit is always read with the value of "0". | | bit6 | SLP:<br>Sleep bit | This bit specifies transition to sleep mode. Writing "1" into this bit allows transition to sleep mode. Writing "0" into this bit does not affect operations. This bit is always read with the value of "0". | | bit5 | SPL:<br>pin state setting bit | This bit specifies external pin states in stop mode. Writing "0" into this bit maintains states (levels) of the external pins at transition to stop mode. Writing "1" into this bit sets states of the external pins to Hi-Z (states of pins for which a pull-up resistor is specified are set to level "H"). This bit becomes "0" after a reset. | | bit4 | RST:<br>Software reset bit | This bit specifies software reset. Writing "0" into this bit generates a source of 4-instruction cycle internal reset. Writing "1" into this bit does not affect operations. This bit is always read with the value of "1". | | bit3 | RESV:<br>Reserved bit | This bit is always read with the value of "0". Writing a value into this bit does not affect operations. | | bit2 to bit0 | Unused bits | Values read out of these bits are undefined. Writing values into these bits does not affect operations. | # 3.7.5 Diagram for State Transition in Standby Mode # Figure 3.7-2 shows the state transition diagram in standby mode. # ■ Diagram for State Transition in Standby Mode Figure 3.7-2 State Transition Diagram Transition to and cancellation of clock mode (non-standby mode) Table 3.7-3 Transition to and Cancellation of Clock Mode | State transition | Transition conditions | |------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------| | Transition to active mode after power-on reset | <ul><li>(9) End of oscillation stabilization wait time (output of time-base timer)</li><li>(1) Cancellation of reset input</li></ul> | | Reset in RUN mode | (2) External reset, software reset, or watchdog reset | Transition to and cancellation of standby mode Table 3.7-4 Transition to and Cancellation of Standby Mode | State transition | Transition conditions | |----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Transition to sleep mode | (3) STBC: SLP=1 | | Cancellation of sleep mode | (6) Interrupt (each type) (4) External reset | | Transition to stop mode | (5) STBC: STP=1 | | Cancellation of stop mode | <ul> <li>(7) External interrupt</li> <li>(8) End of oscillation stabilization wait time (output of the time-base timer)</li> <li>(10) External reset</li> <li>(11) External reset (during oscillation stabilization wait)</li> </ul> | #### Note: In standby mode, the CPU and watchdog timer stop. Thus, software and watchdog resets do not occur. # 3.7.6 Notes on Standby Mode Even if the standby control register (STBC) sets standby mode, transition to standby mode is not allowed when a peripheral function generates an interrupt request. When an interrupt causes a return from standby mode to active mode, subsequent operations depend on whether interrupt requests are acceptable. ## ■ Transition to Standby Mode and Interrupt When an interrupt request with an interrupt level higher than $11_B$ is generated in a peripheral function to the CPU, an attempt to write "1" into the stop bit (STBC: STP) or sleep bit (SLP) in the standby control register is ignored. Therefore, any attempt at transition to standby mode fails. (Even after the interrupt is processed, transition to standby mode is not allowed.) This type of rejection does not depend on whether the CPU can accept interrupts. Even if the CPU is processing an interrupt, transition to standby mode is allowed when the request flag bit for the interrupt has been cleared and there are no other interrupt requests to be processed. ## ■ Cancellation of Standby Mode by an Interrupt When an interrupt request with an interrupt level higher than $11_{\rm B}$ is generated in a peripheral function or another component in sleep mode or stop mode, standby mode is cancelled. This operation does not depend on whether the CPU can accept interrupts. After cancellation of standby mode, the CPU normally takes a branch to the interrupt processing routine if the priority of the interrupt level setting register (ILR1 to ILR4) corresponding to the interrupt request is higher than the level specified in the interrupt level bits (CCR: IL1 and IL0) in the condition code register and if the interrupt enable flag is turned on (CCR: I = 1). Otherwise, an instruction is managed following the instruction causing standby mode to be set. To prohibit a branch to the interrupt processing routine immediately after return, interrupts must be prohibited before standby mode is set. #### ■ Notes on Setting Standby Mode For setting standby mode using the standby control register (STBC), use the settings specified in Table 3.7-5. When 1 is set to both bits at the same time, stop mode has precedence over sleep mode. However, it is recommended that "1" not be set to the bits at the same time. Table 3.7-5 Low-power Consumption Mode Established using the Standby Control Register (STBC) | STBC i | register | Mode | |-----------|-----------|--------| | STP(bit7) | SLP(bit6) | Wode | | 0 | 0 | Active | | 0 | 1 | Sleep | | 1 | 0 | Stop | ## ■ Oscillation Stabilization Wait Time The oscillator for oscillation frequency stops in stop mode, thus oscillation stabilization wait time must be applied after the oscillator is activated. Use one of three clock oscillation stabilization wait time settings generated by the time-base timer. If the interval selected for the time-base timer is shorter than the oscillation stabilization wait time, an interval timer interrupt request is generated during oscillation stabilization wait time. To prevent this from occurring, disable output of time-base timer interrupt requests (TBTC: TBIE = 0) before transition to stop mode when necessary. # 3.8 Memory Access Mode # The MB89202/F202RA series supports only single-chip mode for access to memory. # **■** Single-chip Mode In single-chip mode, only internal RAM and ROM are used. The CPU can access only the internal I/O area, RAM area, and ROM area. #### ■ Mode Data Set $00_{\rm H}$ into the mode data in internal ROM to select single-chip mode. Figure 3.8-1 Configuration of Mode Data # ■ Operations for Selecting Memory Access Mode Only single-chip mode is selectable. Table 3.8-1 provides the settings for the mode pins and mode data. Table 3.8-1 Settings for Mode Data | Memory access mode | Mode data | |--------------------|-----------------| | Single-chip mode | 00 <sub>H</sub> | | Other modes | Prohibited | Figure 3.8-2 shows the operations for selecting memory access. Figure 3.8-2 Operations for Selecting Memory Access # CHAPTER 4 I/O PORTS This chapter describes the functions and operations of I/O ports. - 4.1 Overview of I/O Ports - 4.2 Port 0 - 4.3 Port 3 - 4.4 Port 4 - 4.5 Port 5 - 4.6 Port 6 - 4.7 Port 7 - 4.8 Programming Example of I/O Port # 4.1 Overview of I/O Ports Six I/O ports (comprising 26 pins) are available as general-purpose I/O ports (parallel I/O ports). These ports also serve peripherals (as I/O pins for specific peripheral functions). #### **■** Functions of I/O Ports The I/O ports function to output data from the CPU to I/O pins via their port data register (PDR) and send signals input to I/O pins to the CPU. For some ports, the I/O direction of I/O pins can be set by optionally setting the bits of the port data direction register (DDR), with the bits corresponding to the pins. The functions of the ports and peripherals for which the ports may serve are summarized below. - Port 0: General-purpose I/O port may also serve peripherals (external interrupt 2 and analog input pins) - Port 3: General-purpose I/O port may also serve peripherals (12-bit PPG, external interrupt 1, UART, 8-bit serial I/O, 8/16-bit timers, and buzzer output pin) - Port 4: General-purpose I/O port of a type switched between CMOS push-pull and N-ch open-drain may also serve peripherals (analog input pins) - Port 5: General-purpose I/O port may also serve peripherals (8-bit PWM pin) - Port 6: General-purpose I/O port (for MB89F202/F202RA, P61, P60 are input port) - Port 7: General-purpose I/O port Table 4.1-1 lists the functions of the ports, and Table 4.1-2 lists the register of ports. **Table 4.1-1 Functions of Ports** | Port name | Pin name | Input<br>form | Output<br>form | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-----------|------------------|--------------------|------------------------------------|------------|-------|-------|--------------|-------|-------|-------|-------------| | | P00/INT20/ | Hysteresis | | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 | | Port 0 | AN4 to | CMOS | | ĪNT27 | ĪNT26 | ĪNT25 | ĪNT24 | AN7 | AN6 | AN5 | AN4 | | | P07/INT27 | analog | CMOS | 11(12) | 11120 | 11123 | 11124 | ĪNT23 | ĪNT22 | INT21 | ĪNT20 | | | P30/UCK/SCK | CMOS | push-pull | P37 | P36 | P35 | P34 | P33 | P32 | P31 | P30 | | Port 3 | to<br>P37/BZ/PPG | hysteresis | | BZ/<br>PPG | INT12 | INT11 | TO/<br>INT10 | EC | UI/SI | UO/SO | UCK/<br>SCK | | | P40/AN0 | ar roa | CMOS | | | | | P43 | P42 | P41 | P40 | | Port 4 | to<br>P43/AN3 | CMOS<br>analog | push-pull<br>or N-ch<br>open-drain | - | - | - | - | AN3 | AN2 | AN1 | AN0 | | Port 5 | P50/PWM | CMOS | CMOS | _ | _ | | _ | _ | | | P50 | | FOIL 3 | F30/FWWI | hysteresis | push-pull | - | - | - | - | - | - | - | PWM | | | B-60 | ar roa | CMOS | | | | | | | P61 | P60 | | Port 6 | P60,<br>P61 | CMOS<br>hysteresis | push-pull<br>or N-ch<br>open-drain | - | - | - | - | 1 | - | ı | - | | Port 7 | P70<br>to<br>P72 | CMOS | CMOS | - | - | - | - | - | P72 | P71 | P70 | Table 4.1-2 Registers of Ports | Register name | | Read/Write | Address | Initial value | |-------------------------------------|--------|------------|-------------------|-----------------------| | Port 0 data register | (PDR0) | R/W | 0000 <sub>H</sub> | XXXXXXXX <sub>B</sub> | | Port 0 data direction register | (DDR0) | W *1 | 0001 <sub>H</sub> | 00000000 <sub>B</sub> | | Port 0 pull-up setting register | (PUL0) | R/W | 0070 <sub>H</sub> | 00000000 <sub>B</sub> | | Port 3 data register | (PDR3) | R/W | 000C <sub>H</sub> | XXXXXXXX <sub>B</sub> | | Port 3 data direction register | (DDR3) | W *1 | 000D <sub>H</sub> | 00000000 <sub>B</sub> | | Port 3 pull-up setting register | (PUL3) | R/W | 0071 <sub>H</sub> | 00000000 <sub>B</sub> | | Port 4 data register | (PDR4) | R/W | 000F <sub>H</sub> | XXXX <sub>B</sub> | | Port 4 data direction register | (DDR4) | R/W | 0010 <sub>H</sub> | 0000 <sub>B</sub> | | Port 4 output form setting register | (OUT4) | R/W | 0011 <sub>H</sub> | 0000 <sub>B</sub> | | Port 5 data register | (PDR5) | R/W | 0012 <sub>H</sub> | X <sub>B</sub> | | Port 5 data direction register | (DDR5) | R/W | 0013 <sub>H</sub> | 0 <sub>B</sub> | | Port 5 pull-up setting register | (PUL5) | R/W | 0072 <sub>H</sub> | 0 <sub>B</sub> | | Port 6 data register | (PDR6) | R/W | 0060 <sub>H</sub> | XX <sub>B</sub> | | Port 6 data direction register *2 | (DDR6) | R/W | 0061 <sub>H</sub> | 00 <sub>B</sub> | | Port 6 pull-up setting register | (PUL6) | R/W | 0062 <sub>H</sub> | 00 <sub>B</sub> | | Port 7 data register | (PDR7) | R/W | 0063 <sub>H</sub> | XXX <sub>B</sub> | | Port 7 data direction register | (DDR7) | R/W | 0064 <sub>H</sub> | 000 <sub>B</sub> | | Port 7 pull-up setting register | (PUL7) | R/W | 0065 <sub>H</sub> | 000 <sub>B</sub> | R/W: Readable and Writable $egin{array}{ll} W & : Write \ only \ X & : Undefined \end{array}$ \*1 : DDR0 and DDR3 cannot be used for bit manipulation instructions. \*2 : DDR6 is not used in MB89F202/F202RA. # 4.2 Port 0 Port 0 is a general-purpose I/O port and may also serve as peripheral inputs. The pins of this port can be used for peripherals or normal port function that can be selected according to the setting of a bit corresponding to the pin on a specific register. This section mainly explains the general-purpose I/O function of the port. This section also describes the structure, pins, and associated registers of port 0 and provides a block diagram of pins. #### ■ Structure of Port 0 Port 0 comprises the following four elements: - General-purpose I/O pins, external interrupt 2, and analog input pins (P00/INT20/AN4 to P07/INT27) - Port 0 data register (PDR0) - Port 0 data direction register (DDR0) - Port 0 pull-up setting register (PUL0) #### ■ Pins of Port 0 Port 0 has eight general-purpose I/O pins. When used as input pins at the same time, these pins can be also used as external interrupt input pins. Table 4.2-1 lists the pins of port 0. Table 4.2-1 Pins of Port 0 | Port | Pin name Function | | Peripherals for which a pin | Input and ou | Circuit | | |--------|----------------------------|----------------------------------------------------|-------------------------------------------------------------|--------------|----------|------| | name | Pili liaille | may serve | | Input | Output | type | | | P00/INT20/AN4 | N4 P00 general-<br>purpose I/O N4 : analog input 4 | | | | | | | P01/INT21/AN5 | P01 general-<br>purpose I/O | INT21 : external interrupt input 21<br>AN5 : analog input 5 | Analog CMOS | - CMOS - | G | | - | P02/ <del>INT22</del> /AN6 | P02 general-<br>purpose I/O | INT22 : external interrupt input 22<br>AN6 : analog input 6 | hysteresis | | u u | | | P03/INT23/AN7 | P03 general-<br>purpose I/O | INT23 : external interrupt input 23<br>AN7 : analog input 7 | | | | | Port 0 | P04/ <del>INT24</del> | P04 general-<br>purpose I/O | INT24 : external interrupt input 24 | | | | | | P05/INT25 | P05 general-<br>purpose I/O | INT25 : external interrupt input 25 | CMOS | | D | | | P06/INT26 | P06 general-<br>purpose I/O | I IN I /b : external interribit input /b I | | | D | | | P07/INT27 | P07 general-<br>purpose I/O | INT27 : external interrupt input 27 | | | | For circuit type, see Section "1.7 Pin Functions Description " and "1.8 I/O Circuit Types ". For pin operation when used as analog input, see "CHAPTER 12 A/D CONVERTER". # ■ Block Diagram of Port 0 A/D converter channel select A/D converter enable bit ⟨□ A/D input occurring To A/D converter's analog input From external interrupt enable External Stop mode (SPL=1) External □ No A/D input Internal data bus PDR PDR read PDR read (when read-modify-write is performed) Pull-up resistor Pch Output latch PDR write Pins Nch DDR DDR write Stop mode (SPL=1) PUL read PUL PUL write SPL: Pin status setting bit of standby control register (STBC) Figure 4.2-1 Block Diagram of Port 0 Note: When the A/D converter is used, deselect pull-up action for pins P03/INT23/AN7 to P00/INT20/AN4. Pins set to be used as analog input pins must not be used as an output port. # ■ Registers PDR0, DDR0, and PUL0 of Port 0 Registers PDR0, DDR0, and PUL0 are associated with port 0. The bits of these registers correspond to the pins of port 0 in one-to-one correspondence. Table 4.2-2 tabulates the correspondence between the pins and the bits of the port 0 registers. Table 4.2-2 Correspondence between the Pins and the Bits of the Port 0 Registers | Port name Bits of associated registers and corresponding pins | | | | | | | | | | |---------------------------------------------------------------|--------------------------|------|------|------|------|------|------|------|------| | Port 0 | PDR0, DDR0, PUL0 | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | roit 0 | Pin corresponding to bit | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 | # 4.2.1 Registers of Port 0 (PDR0, DDR0, and PUL0) # This section describes the registers associated with port 0. ## **■** Functions of Port 0 Registers # Port 0 data register (PDR0) The PDR0 register indicates the state of the output latch. For a pin set to function as an output port, the same value ("0" or "1") as the value state of the output pin can be read from this register. If the pin is set to function as an input port, however, its output latch value cannot be read from the register. #### Note: When a bit manipulation instruction (SETB, CLRB) is executed, the output latch values, not the value states of the pins, are read; thus, output latch values, other than those for bits to be manipulated, do not change. #### Port 0 data direction register (DDR0) The DDR0 register sets the I/O direction of each pin per bit. When a bit of the DDR0 register corresponding to a pin of port 0 is set to "1", the pin functions as an output port. When the bit is set to "0", the pin functions as an input port. Note: Because the DDR0 register is write only, bit manipulation instructions (SETB, CLRB) do not apply. ## Setting a port pin to serve external interrupt inputs If a pin of port 0 is used as an external interrupt input pin, enable the external interrupt circuit operation and set the pin to function as an input port. When the pin is set in this mode, its output latch value has no significance. #### Setting a port pin to serve analog inputs If a pin of port 0 is used as an analog input pin, write "0" for the bit corresponding to the pin on the DDR0 register. The output transistor is then set to OFF and the pin is set in the Hi-Z state. Set the bit of the ADEN register of the A/D converter to "1", the bit corresponding to the analog input pin in use. #### Setting the input to a peripheral enable If a peripheral with an input pin is used, set the pin of port 0 for the input to the peripheral to function as an input port. In this mode, the corresponding output latch value has no significance. Table 4.2-3 lists the functions of the port 0 registers. Table 4.2-3 Functions of Port 0 Registers | Register name | Data | When being read | When being written | Read/<br>Write | Address | Initial value | | |------------------------------|------|----------------------------|--------------------------------------------------------------------------------------|----------------|-------------------|---------------|--| | Port 0 data | 0 | Pin state is "L" level. | Output latch of "0" is set and "L" level is output to the pin in output port mode. | R/W | 0000н | XXXXXXXX | | | register (PDR0) | 1 | Pin state is "H" level. | Output latch of "1" is set and "H" level is output to the pin in output port mode. | IV W | оооон | лллллл | | | Port 0 data | | | Output transistor operation is disabled and the pin is set to serve as an input pin. | W | 0001 | 0000000 | | | direction<br>register (DDR0) | 1 | prohibited<br>(write only) | Output transistor operation is enabled and the pin is set to serve as output pin. | vv | 0001 <sub>H</sub> | 00000000B | | R/W: Readable/Writable W : Write onlyX : Undefined ## Port 0 pull-up setting register (PUL0) The bits of the pull-up setting register correspond to the pins of port 0 in one-to-one correspondence. When the pull-up resistor is selected by using the pull-up setting register, the pin will be at "H" level (pull-up state) instead of Hi-Z during stop (SPL = 1). During a reset, however, the pull-up is invalid and the pin remains at Hi-Z. Figure 4.2-2 shows the pull-up resistor settings assigned to the values of the bits of the port 0 pull-up register. Figure 4.2-2 Pull-up Resistor Settings (PUL0) # 4.2.2 Operations of Port 0 Functions ## This section describes the operation of port 0. # ■ Operation of Port 0 #### Operation in output port mode When "1" is written to a bit of the DDR0 register, the bit corresponding to a pin of port 0, the pin functions as an output port. In output port mode, the output transistor operation is enabled and the output latch data is output to the pin. Once data has been written into the PDR0 register, the written data is held in the output latch and output to the pin as it is. The value state of the pin can be read by reading the PDR0 register. #### Operation in input port mode When "0" is written to a bit of the DDR0 register, the bit corresponding to a pin of port 0, the pin functions as an input port. In input port mode, the output transistor is OFF and the pin status is Hi-Z. Once data has been written into the PDR0 register, the written data is held in the output latch but is not output to the pin. The value state of the pin can be read by reading the PDR0 register. #### Operation in external interrupt input mode Set a bit of the DDR0 register to "0", the bit corresponding to a pin of port 0 that is to serve as an external interrupt input pin, to set the pin to function as an input port. The value state of the pin can be read by reading the PDR0 register regardless of whether external interrupt inputs or interrupt request outputs are enabled or disabled. #### Operation in analog input mode To use a pin of port 0 as analog input and to inhibit output transistor operation, set the bit corresponding to the analog input pin to "0" on the DDR0 register. The value state of the pin can be read by reading the PDR0 register. Set the bit of the ADEN register of the A/D converter to "1", the bit corresponding to the analog input pin in use. #### Operation when a reset is performed When the CPU is reset, the bits of the DDR0 register are initialized to "0". Thus, all output transistors become OFF and the pins become Hi-Z. However, CPU resets do not initialize the PDR0 register. If a pin is used as an output port after the reset, reinitialize the PDR0 register to contain new output data in the bit position corresponding to the pin and then set the corresponding bit of the DDR0 register so that the pin will function as an output port. #### Operation in stop mode When the pin state setting bit of the standby control register (STBC: SPL) is "1" and when the stop mode is entered, the output transistor is turned OFF and the pin becomes Hi-Z because the output transistor is forcibly turned OFF without respect to the value existing on the DDR0 register in the bit position corresponding to the pin. Input remains fixed to prevent leaks by input open. Table 4.2-4 summarizes the operating modes of the pins of port 0. Table 4.2-4 Operating Modes of Pins of Port 0 | Pin name | Normal operation, sleep, stop (SPL = 0) | Stop (SPL = 1) | At a reset | |--------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------|------------| | P00/ <u>INT20</u> /AN4<br>to<br>P03/ <u>INT23</u> /AN7 | General-purpose I/O port may also serve external interrupt inputs or analog inputs | Hi-Z | Hi-Z | | P04/INT24<br>to<br>P07/INT27 | General-purpose I/O port may also serve external interrupt inputs | (External interrupt input) | 111-2 | SPL: Pin state setting bit of standby control register (STBC: SPL) Hi-Z: High impedance #### Note: When the pull-up resistor is selected by using the pull-up setting register, the pin state will be "H" level instead of Hi-Z in stop mode (SPL = 1). During a reset, however, the pull-up is invalid with the pin remaining at Hi-Z. # 4.3 Port 3 Port 3 is a general-purpose I/O port and may also serve as input pins for external interrupts as well as input and output pins for peripherals. This section mainly explains the general-purpose I/O function of the port. This section also describes port 3 concerning to the structure, pins, a block diagram of pins, and associated registers. #### ■ Structure of Port 3 Port 3 comprises the following four elements: - General-purpose I/O pins, external interrupt 1 input pins, and input/output pins for peripherals (P30/ UCK/SCK to P37/BZ/PPG) - Port 3 data register (PDR3) - Port 3 data direction register (DDR3) - Port 3 pull-up setting register (PUL3) #### ■ Pins of Port 3 Port 3 has eight CMOS I/O pins. These pins can be used as both input pins and external interrupt input pins at the same time. These pins cannot be used as a general-purpose I/O port when being used for peripherals. Table 4.3-1 lists the pins of port 3. Table 4.3-1 Pins of Port 3 | Port | Pin name | Function | Porinhe | arala for which the nin may corve | Input and or | utput form | Circuit | |--------|-----------------------------------|----------------------------|-------------|-------------------------------------------------------------------------|--------------------|------------|---------| | name | Fin name | runction | Periprie | erals for which the pin may serve | Input | Output | type | | | P30/UCK/SCK | P30 general-purpose<br>I/O | UCK<br>SCK | UART clock I/O<br>8-bit serial I/O clock I/O | CMOS<br>hysteresis | | В | | | P31/UO/SO | P31 general-purpose<br>I/O | UO<br>SO | UART data output<br>8-bit serial I/O data output | CMOS | | E | | | P32/UI/SI | P32 general-purpose<br>I/O | UI<br>SI | UART data input<br>8-bit serial I/O data input | CMOS<br>hysteresis | | | | Port 3 | P33/EC | P33 general-purpose<br>I/O | EC | 8/16-bit timer and counter clock inputs | | | | | Port 3 | P34/TO/INT10 | P34 general-purpose<br>I/O | TO<br>INT10 | 8/16-bit timer and counter timer outputs<br>External interrupt input 10 | CMOS | CMOS | В | | | P35/INT11 | P35 general-purpose<br>I/O | INT11 | External interrupt input 11 | hysteresis | | | | | P36/INT12 P36 general-purpose I/O | | INT12 | External interrupt input 12 | | | | | | P37/BZ/PPG | P37 general-purpose<br>I/O | BZ<br>PPG | Buzzer output<br>12-bit PPG output | CMOS | | Е | For circuit type, see "1.7 Pin Functions Description". # ■ Block Diagram of Port 3 Figure 4.3-1 Block Diagram of Port 3 #### Note: Because the value states of the pins are always input to the external interrupt circuit, when a pin is used as a normal I/O port, the operation of the external interrupt circuit corresponding to the pin must be inhibited. See "CHAPTER 10 EXTERNAL INTERRUPT CIRCUIT 1 (EDGE)". ## ■ Registers PDR3, DDR3, and PUL3 of Port 3 The registers PDR3, DDR3, and PUL3 are associated with port 3. The bits of these registers correspond to the pins of port 3 in one-to-one correspondence. Table 4.3-2 tabulates the correspondence between the pins and the bits of port 3 registers. Table 4.3-2 Correspondence between the Pins and the Bits of Port 3 Registers | Port name | Bits of associated registers and corresponding pins | | | | | | | | | |-----------|-----------------------------------------------------|------|------|------|------|------|------|------|------| | Port 3 | PDR3, DDR3, PUL3 | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | Polt 3 | Pin corresponding to bit | P37 | P36 | P35 | P34 | P33 | P32 | P31 | P30 | # 4.3.1 Registers of Port 3 (PDR3, DDR3, PUL3) # This section describes the registers associated with port 3. ## **■** Functions of Port 3 Registers #### Port 3 data register (PDR3) The PDR3 register indicates the state of the pins. For a pin set to function as an output port, the same value ("0" or "1") as held by the output latch can be read from this register. If the pin is set to function as an input port, however, its output latch value cannot be read from the register. #### Note: When a bit manipulation instruction (SETB, CLRB) is executed, the output latch values, not the value states of the pins, are read; thus, output latch values, excepting those for bits to be manipulated, do not change. #### Port 3 data direction register (DDR3) The DDR3 register sets the I/O direction of each pin per bit. When a bit of the DDR3 corresponding to a pin of port 3 is set to "1", the pin functions as an output port. When the bit is set to "0", the pin functions as an input port. #### Note: Because the DDR3 register is write only, bit manipulation instructions (SETB, CLRB) do not apply. ## Setting a port pin to serve external interrupts If a pin of port 3 is used as an external interrupt input pin, enable the external interrupt circuit operation and set the pin to function as an input port. When the pin is set in this mode, its output latch value has no significance. #### Setting the output from a peripheral enable If a peripheral with an output pin is used, set the output enable bit of the peripheral enable. Because the output from the peripheral has priority, the values set on the PDR3 and DDR3 registers in the bit position corresponding to the output pin for the peripheral have no significance, regardless of the value output from the peripheral and the output enabled. #### Setting the input to a peripheral enable If a peripheral with an input pin is used, set the pin of port 3 for the input to the peripheral to function as an input port. In this mode, the corresponding output latch value has no significance. Table 4.3-3 lists the functions of port 3 registers. Table 4.3-3 Functions of Port 3 Registers | Register name | Data | When being read | When being written | Read/<br>Write | Address | Initial value | | |-----------------------|-----------|----------------------------|--------------------------------------------------------------------------------------|----------------|---------------------|-----------------------|--| | Port 3 data | 0 | Pin state is "L" level. | Output latch of "0" is set and "L" level is output to the pin in output port mode. | R/W | 0000 | VVVVVVV | | | register<br>(PDR3) | 1 | Pin state is "H" level. | Output latch of "1" is set and "H" level is output to the pin in output port mode. | R/W | 000C <sub>H</sub> | XXXXXXXX <sub>B</sub> | | | Port 3 data direction | rion Read | | Output transistor operation is disabled and the pin is set to serve as an input pin. | w | 000D | 00000000p | | | register (DDR3) | 1 | prohibited<br>(write only) | Output transistor operation is enabled and the pin is set to serve as an output pin. | W | $000D_{\mathrm{H}}$ | 00000000 <sub>B</sub> | | R/W: Readable and Writable W : Write onlyX : Undefined ## Port 3 pull-up setting register (PUL3) The bits of the pull-up setting register correspond to the pins of port 3 in one-to-one correspondence. When the pull-up resistor is selected by using the pull-up setting register, the pin state will be "H" level (pull-up state) instead of Hi-Z during stop (SPL = 1). During a reset, however, the pull-up is invalid and the pin remains at Hi-Z. Figure 4.3-2 shows the pull-up resistor settings assigned to the values of the bits of the port 3 pull-up register. Figure 4.3-2 Pull-up Setting Register (PUL3) # 4.3.2 Operations of Port 3 Functions # This section describes the operation of port 3. # ■ Operation of Port 3 #### Operation in output port mode When "1" is written for a bit of the DDR3 register, the bit corresponding to a pin of port 3, the pin functions as an output port. In output port mode, output transistor operation is enabled and output latch data is output to the pin. Once data has been written into the PDR3 register, the written data is held in the output latch and output to the pin as it is. The value state of the pin can be read by reading the PDR3 register. #### Operation in input port mode When "0" is written for a bit of the DDR3 register, the bit corresponding to a pin of port 3, the pin functions as an input port. In input port mode, the output transistor is OFF and the pin state is Hi-Z. Once data has been written into the PDR3 register, the written data is held in the output latch but is not output to the pin. The value state of the pin can be read by reading the PDR3 register. #### Operation in external interrupt input mode Set a bit of the DDR3 register to "0", the bit corresponding to a pin of port 3 that is to serve as an external interrupt input pin, to set the pin to function as an input port. The value state of the pin can be read by reading the PDR3 register regardless of whether or not the external interrupt inputs or interrupt request outputs are enabled. #### Operation in mode enabling the output from a peripheral When the output enable bit for a peripheral is set to enable, the corresponding pin is set to serve the output from the peripheral. Because the value state of the pin can be read from the PDR3 register even when the output from the peripheral is enabled, the value output from the peripheral can be read. #### Operation in mode enabling the input to a peripheral Set a bit of the DDR3 register to "0", the bit corresponding to the pin of port 3 assigned for the input to the desired peripheral, for the pin to function as an input port. The value state of the pin is always input to the peripheral (except during stop mode). The value state of the pin can be read by reading the PDR3 register regardless of whether or not the peripheral is using the input pin. #### Operation when a reset is performed When the CPU is reset, the bits of the DDR3 register are initialized to "0", at which time the output transistors become OFF (input port mode) and the pins become Hi-Z. However, CPU resets do not initialize the PDR3 register. If a pin is used as an output port after the reset, reinitialize the PDR3 register to contain new output data in the bit position corresponding to the pin and then set the corresponding bit of the DDR3 register so that the pin will function as an output port. #### Operation in stop mode When the pin state setting bit of the standby control register (STBC: SPL) is set to "1" and when the stop mode is entered, the pin becomes Hi-Z because the output transistor is turned OFF regardless of the value existing on the DDR3 register in the bit position corresponding to the pin. Table 4.3-4 summarizes the operating modes of the pins of port 3. Table 4.3-4 Operating Modes of Pins of Port 3 | Pin name | Pin name Normal operation, sleep, stop (SPL = 0) | | At a reset | |-----------------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------|------------| | P30/UCK/SCK<br>to<br>P33/EC, P37/BZ/PPG | General-purpose I/O port may also serve I/O for peripherals | Hi-Z | Hi-Z | | P34/TO/INT10<br>to<br>P36/INT12 | General-purpose I/O port may also<br>serve outputs from peripherals and<br>external interrupt inputs | Hi-Z<br>(External interrupt input) | 111-2 | SPL: Pin state setting bit of standby control register (STBC: SPL) Hi-Z: High impedance #### Note: When the pull-up resistor is selected by using the pull-up setting register, the pin state will be "H" level instead of Hi-Z in stop mode (SPL = 1). During a reset, however, the pull-up is invalid with the pin remaining at Hi-Z. # 4.4 Port 4 Port 4 is a type of I/O port that is switched between CMOS push-pull and N-ch opendrain and may also serve analog inputs. Each pin of this port can be used for peripherals or normal port function that can be selected according to the setting of the bit corresponding to the pin on a specific register. This section explains the I/O port function of CMOS push-pull/ N-ch open-drain type. This section also describes port 4 concerning to the structure, pins, a block diagram of pins, and associated registers. #### ■ Structure of Port 4 Port 4 comprises the following four elements: - Type of I/O pins that are switched between CMOS push-pull and N-ch open-drain and analog input pins (P40/AN0 to P43/AN3) - Port 4 data register (PDR4) - Port 4 data direction register (DDR4) - Port 4 output format setting register (OUT4) #### ■ Pins of Port 4 Port 4 has four I/O pins of CMOS push-pull/N-ch open-drain. These pins can also be used as analog input pins. Those pins that are used for analog inputs cannot be used as a general-purpose I/O port. Table 4.4-1 lists the pins of port 4. Table 4.4-1 Pins of Port 4 | Port | Pin | | Peripherals for | Input a | nd output form | Circuit | |--------|---------|--------------------------------------|--------------------|---------|--------------------------|---------| | name | name | ame Function which the pin may serve | | Input | Output | type | | | P40/AN0 | P40 I/O | AN0 analog input 0 | | | | | Port 4 | P41/AN1 | P41 I/O | AN1 analog input 1 | CMOS | CMOS push- | F | | FOIL 4 | P42/AN2 | P42 I/O | AN2 analog input 2 | analog | pull/N-ch open-<br>drain | Г | | | P43/AN3 | P43 I/O | AN3 analog input 3 | | | | For circuit type, see Section "1.7 Pin Functions Description " and "1.8 I/O Circuit Types ". # ■ Block Diagram of Port 4 A/D converter channel select A/D converter enable bit To A/D converter's analog input PDR Stop mode (SPL = 1) PDR read PDR read (when read-modify-write is performed) Internal data bus Output latch PDR write Pins DDR write Nch DDR DDR read Stop mode (SPL = 1) **OUT** read OUT OUT write Figure 4.4-1 Block Diagram of Port 4 # ■ Registers of Port 4 The registers PDR4, DDR4, and OUT4 are associated with port 4. The bits of these registers correspond to the pins of port 4 in one-to-one correspondence. Table 4.4-2 tabulates the correspondence between the pins and the bits of the port 4 registers. Table 4.4-2 Correspondence between the Pins and the Bits of the Port 4 Register | Port name | Bits of associated registers and corresponding pins | | | | | | | | | |-----------|-----------------------------------------------------|------|------|------|------|------|------|------|------| | Port 4 | PDR4, DDR4, OUT4 | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | F011 4 | Pin corresponding to bit | - | - | - | - | P43 | P42 | P41 | P40 | # 4.4.1 Registers of Port 4 (PDR4) # This section describes the registers associated with port 4. ## **■** Functions of Port 4 Registers #### Port 4 data register (PDR4) The PDR4 register indicates the state of the pins. For a pin set to function as an output port, the same value ("0" or "1") as held by the output latch can be read from this register. If the pin is set to function as an input port, however, its output latch value cannot be read from the register. #### Note: When a bit manipulation instruction (SETB, CLRB) is executed, the output latch values, not the value states of the pins, are read; thus, output latch values, excepting those for bits to be manipulated, do not change. Table 4.4-3 lists the functions of the port 4 registers. Table 4.4-3 Functions of Port 4 Registers | Register name | Data | When being read | | When being written | Read/<br>Write | Address | Initial<br>value | |-----------------------------------------|------------------------------------------------------------------------------------|-----------------|---------------------------|------------------------------------------------------------------------------------|----------------|-------------------|-------------------| | | Output latch of "0" is set and "L" level is output to the pin in output port mode. | | | | | | | | Port 4<br>data<br>register<br>(PDR4) | 1 | Pin state | N-ch open-<br>drain type | Output latch of "1" is set and the pin in output port mode is set at Hi-Z. | R/W | 000F <sub>H</sub> | XXXX <sub>B</sub> | | , , | 1 | level. | CMOS<br>push-pull<br>type | Output latch of "1" is set and "H" level is output to the pin in output port mode. | | | | | Port 4<br>data<br>direction | 0 | Inpu | t port pin | The pin is set to function as input pin with output transistor operation disabled. | R/W | 0010 <sub>H</sub> | 0000 <sub>B</sub> | | register<br>(DDR4) | 1 | Outpu | ıt port pin | The pin is set to function as output pin with output transistor operation enabled. | K/W | 0010 <sub>H</sub> | 0000 <sub>B</sub> | | Port 4<br>output | 0 | N-ch open | -drain type | Output format of the pin is set to N-ch open-drain type. | | | | | format<br>setting<br>register<br>(OUT4) | 1 | CMOS pus | sh-pull type | Output format of the pin is set to CMOS push-pull type. | R/W | 0011 <sub>H</sub> | 0000 <sub>B</sub> | R/W: Readable and Writable X: Undefined # 4.4.2 Operations of Port 4 Functions ## This section describes the operation of port 4. ## ■ Operation of Port 4 #### Operation in output port mode When "1" is written for a bit of the DDR4 register, the bit corresponding to a pin of port 4, the pin functions as an output port. In output port mode, the output transistor operation is enabled and output latch data is output to the pin. By setting the bit corresponding to the pin on the OUT4 register, N-ch open-drain or CMOS push-pull type can be selected as the output format of the pin. Once data has been written into the PDR4 register, the written data is held in the output latch and output to the pin as it is. The value state of the pin can be read by reading the PDR4 register. #### Analog input mode setting Set a bit of the DDR4 register to "0", the bit corresponding to a pin of port 4 assigned for desired analog input, so that its output transistor is set to OFF and the pin is set at Hi-Z. Its output latch value can be read by reading the PDR4 register. Set the bit of the ADEN register of the A/D converter to "1", the bit corresponding to the analog input pin in use. #### Operation when a reset is performed When the CPU is reset, the bits of the PDR4 register are initialized to "1". Thus, the output transistors become OFF (input port mode) and the pins become Hi-Z. #### Operation in stop mode When the pin state setting bit of the standby control register (STBC: SPL) is set to "1" and when the stop mode is entered, the pin becomes Hi-Z because the output transistor is turned OFF regardless of the value existing on the DDR4 register in the bit position corresponding to the pin. Input remains fixed to prevent leaks by input open. Table 4.4-4 summarizes the operating modes of the pins of port 4. Table 4.4-4 Operating Modes of Pins of Port 4 | Pin name | Normal operation, sleep, stop (SPL = 0) | Stop (SPL = 1) | At a reset | |--------------------|-------------------------------------------------------------|----------------|------------| | P40/AN0 to P43/AN3 | General-purpose I/O port may also serve I/O for peripherals | Hi-Z | Hi-Z | SPL: Pin state setting bit of standby control register (STBC: SPL) Hi-Z: High impedance ## 4.5 Port 5 Port 5 is a general-purpose I/O port and may also serve the input/output for peripherals. The pins of this port can be used for peripherals or normal port function that can be selected according to the setting of the bit corresponding to the pin on a specific register. This section explains the general-purpose I/O function of the port. This section also describes port 5 concerning to the structure, pins, a block diagram of pins, and associated registers. #### ■ Structure of Port 5 Port 5 comprises the following four elements: - General-purpose I/O pins (P50/PWM) - Port 5 data register (PDR5) - Port 5 data direction register (DDR5) - Port 5 pull-up setting register (PUL5) ## ■ Pins of Port 5 Port 5 has one CMOS I/O pin. Table 4.5-1 provides information on the pin of port 5. Table 4.5-1 Pin of Port 5 | Port | Pin name | Function | Peripherals for which the pin may serve | - | nd output<br>orm | Circuit<br>type | | |--------|----------|-----------------------------|-----------------------------------------|-------|------------------|-----------------|--| | name | | | pin may serve | Input | Output | type | | | Port 5 | P50/PWM | P50 general-<br>purpose I/O | PWM (8-bit PWM/timer output) | CMOS | CMOS | Е | | For circuit type, see Section "1.7 Pin Functions Description " and "1.8 I/O Circuit Types ". ## ■ Block Diagram of Port 5 Figure 4.5-1 Block Diagram of Port 5 ## ■ Registers of Port 5 The registers PDR5, DDR5, and PUL5 are associated with port 5. One of the bits of these registers corresponds to one pin of port 5. Table 4.5-2 tabulates the correspondence between the pin and a bit of the port 5 registers. Table 4.5-2 Correspondence between the Pin and a Bit of the Port 5 Registers | Port name | Bits of as | Bits of associated registers and corresponding pins | | | | | | | | |-----------|--------------------------|-----------------------------------------------------|------|------|------|------|------|------|------| | Don't 5 | PDR5, DDR5, PUL5 | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | Port 5 | Pin corresponding to bit | - | - | - | - | - | - | - | P50 | # 4.5.1 Registers of Port 5 (PDR5, DDR5, PUL5) ## This section describes the registers associated with port 5. ## **■** Functions of Port 5 Registers #### Port 5 data register (PDR5) The PDR5 register indicates the state of pins. For a pin set to function as an output port, the same value ("0" or "1") as held by the output latch can be read from this register. If the pin is set to function as an input port, however, its output latch value cannot be read from the register. #### Note: When a bit manipulation instruction (SETB, CLRB) is executed, the output latch values, not the value states of the pins, are read; thus, output latch values, excepting those for bits to be manipulated, do not change. #### Port 5 data direction register (DDR5) A bit of the DDR5 register sets the I/O direction of the pin corresponding to the bit. When the bit of the DDR5 register is set to "1", the pin functions as an output port. When the bit is set to "0", the pin functions as an input port. #### Setting the output from a peripheral enable If a peripheral with an output pin is used, set the output enable bit of the peripheral enable. As it is apparent from the block diagram, the pin in this mode serves output from the peripheral, thereby superseding its general-purpose port function. Because the output from the peripheral has priority, the values set on the PDR5 and DDR5 registers for the output pin used for the peripheral have no significance, regardless of the value output from the peripheral and the output enabled. Table 4.5-3 lists the functions of the port 5 registers. Table 4.5-3 Functions of Port 5 Registers | Register name | Data | When being read | When being<br>written | Read/Write | Address | Initial value | |--------------------------|------|-------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------|--------------------|----------------| | Port 5 data | 0 | Pin state is "L" level. | Output latch of "0" is set and "L" level is output to the pin in output port mode. | R/W | 00012 | v | | register<br>(PDR5) | 1 | Pin state is "H" level. | Output latch of "1" is set and the pin in output port mode is set at Hi-Z. | IV, W | 00012 <sub>H</sub> | X <sub>B</sub> | | Port 5 data<br>direction | 0 | Input port pin | The pin is set to function as an input pin with output transistor operation disabled. | R/W | 0013 <sub>Н</sub> | 0 <sub>R</sub> | | register (DDR5) | 1 | Output port pin | The pin is set to function as an output pin with output transistor operation enabled. | n is set to n as an output h output or operation | | OB | R/W: Readable/Writable X : Undefined ## Port 5 pull-up setting register (PUL5) When the ON setting of the pull-up resistor is selected by using the pull-up setting register, the pin state will be "H" level (pull-up state) instead of Hi-Z during stop (SPL=1). During a reset, however, the pull-up is invalid and the pin remains at Hi-Z. Figure 4.5-2 Pull-up Setting Register (PUL5) # 4.5.2 Operations of Port 5 Functions ## This section describes the operation of port 5. ## ■ Operation of Port 5 #### Operation in output port mode When "1" is written for a bit of the DDR5 register, the bit corresponding to the pin of port 5, the pin functions as an output port. In output port mode, the output transistor operation is enabled and the output latch data is output to the pin. Once data has been written into the PDR5 register, the written data is held in the output latch and output to the pin as it is. The value state of the pin can be read by reading the PDR5 register. #### Operation in input port mode When "0" is written for a bit of the DDR5 register, the bit corresponding to the pin of port 5, the pin functions as an input port. In input port mode, the output transistor is OFF and the pin state is Hi-Z. Once data has been written into the DDR5 register, the written data is held in the output latch but is not output to the pin. The value state of the pin can be read by reading the PDR5 register. #### Operation in mode enabling the output from a peripheral When the output enable bit for a peripheral is set enable, the corresponding pin is set to serve the output from the peripheral. Because the value state of the pin can be read from the PDR5 register even when the output from the peripheral is enabled, the value output from the peripheral can be read. #### Operation when a reset is performed When the CPU is reset, the bits of the DDR5 register are initialized to "0". Thus, the output transistor becomes OFF (input port mode) and the pin becomes Hi-Z. However, CPU resets do not initialize the PDR5 register. If the pin is used as an output port after the reset, reinitialize the PDR5 register to contain new output data in the bit position corresponding to the pin and then set the corresponding bit of the DDR5 register so that the pin will function as an output port. #### Operation in stop mode When the pin state setting bit of the standby control register (STBC: SPL) is set to "1" and when the stop mode is entered, the pin becomes Hi-Z because the output transistor is turned OFF regardless of the value existing on the DDR5 register in the bit position corresponding to the pin. Input remains fixed to prevent leaks by input open. Table 4.5-4 summarizes the operating modes of the pin of port 5. Table 4.5-4 Operating Modes of Pin of Port 5 | Pin name | Normal operation, sleep, stop (SPL = 0) | Stop (SPL = 1) | At a reset | |----------|----------------------------------------------------------------|----------------|------------| | P50/PWM | General-purpose I/O port further may serve I/O for peripherals | Hi-Z | Hi-Z | SPL: Pin state setting bit of standby control register (STBC: SPL) Hi-Z: High impedance #### Note: If the pull-up resistor is selected by using the pull-up setting register, the pin state will be "H" level (pull-up state) instead of Hi-Z in stop mode (SPL=1). During a reset, however, the pull-up is invalid with the pin remaining at Hi-Z. ## 4.6 Port 6 Port 6 is a general-purpose I/O port. This section describes the port function when operating as general-purpose I/O port. This section also describes the structure, pins, the block diagram of pins, and associated registers of port 6. #### ■ Structure of Port 6 Port 6 comprises the following four elements: - General-purpose I/O pins (input pins P61-P60 for MB89F202/F202RA) - Port 6 data register (PDR6) - Port 6 data direction register (DDR6, not used in MB89F202/F202RA) - Port 6 pull-up setting register (PUL6) #### ■ Pins of Port 6 Port 6 has 2 I/O pins of CMOS input type (they are input only pins for MB89F202/F202RA). Table 4.6-1 lists the pins of port 6. Table 4.6-1 Pins of Port 6 | Dout ware | Di | F | Peripherals for | Input and out | Circuit | | |-----------|---------------------------------|---|--------------------------|---------------|---------|------| | Port name | Pin name Function which a pin r | | which a pin may<br>serve | Input | Output | type | | Dort 6 | P60 Port 6 P61 | | - | CMOS | - | H/E | | Folto | | | - | CMOS | - | H/E | <sup>\*:</sup> P61 and P60 are general-purpose input port for MB89F202/F202RA. For circuit type, see Section "1.7 Pin Functions Description " and "1.8 I/O Circuit Types ". ## ■ Block Diagram of Port 6 Figure 4.6-1 Block Diagram of Port6 ## ■ Registers PDR6, DDR6, and PUL6 of Port 6 Registers PDR6, DDR6, and PUL6 are associated with port 6. The bits of these registers correspond to the pins of port 6 in one-to-one correspondence. Table 4.6-2 tabulates the correspondence between the pins and the bits of the port 6 registers. Table 4.6-2 Correspondence between the Pins and the Bits of Port 6 Registers | Port name | Bits of as | Bits of associated registers and corresponding pins | | | | | | | | |-----------|--------------------------|-----------------------------------------------------|------|------|------|------|------|------|------| | Dort 6 | PDR6, DDR6, PUL6 | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | Port 6 | Pin corresponding to bit | - | - | - | - | = | - | P61* | P60* | <sup>\*:</sup> DDR control is not used for this bit in MB89F202/F202RA. ## 4.6.1 Registers of Port 6 (PDR6, DDR6, PUL6) ## This section describes the registers associated with port 6. ## **■** Functions of Port 6 Registers #### Port 6 data register The PDR6 register indicates the state of the output latch. For a pin set to function as an output port, the same value ("0" or "1") as the value state of the output pin can be read from this register. If the pin is set to function as an input port, however, its output latch value cannot be read from the register. #### Note: When a bit manipulation instruction (SETB, CLRB) is executed, the output latch values, not the value states of the pins, are read; thus, output latch values, other than those for bits to be manipulated, do not change. #### Port 6 data direction register (DDR6 for P60, P61) The DDR6 register sets the I/O direction of each pin per bit. When a bit of the DDR6 corresponding to a pin of port 6 is set to "1", the pin functions as an output port. When the bit is set to "0", the pin functions as an input port. Table 4.6-3 lists the functions of the port 6 registers. Table 4.6-3 Functions of Port 6 Registers | Register name | Data | When being read | When being written | Read/<br>Write | Address | Initial value | | |-----------------|-------------------------------------------------------------------------------------------------------------|-------------------------|--------------------------------------------------------------------------------------|----------------|-------------------|-----------------|--| | Port 6 data | 0 | Pin state is "L" level. | Output latch of "0" is set and "L" level is output to the pin in output port mode. | R/W | 0060 | XX <sub>R</sub> | | | register (PDR6) | Pin state is "H" level. Output latch of "1" is set and "H" level is output to the pin in output port mode. | 0060 <sub>H</sub> | АЛВ | | | | | | Port 6 data | 0 | Input port | Output transistor operation is disabled and the pin is set to serve as an input pin. | R/W | 0061 | 00 | | | register (DDR6) | 1 | Output port | Output transistor operation is enabled and the pin is set to serve as output pin. | K/W | 0061 <sub>H</sub> | 00 <sub>B</sub> | | R/W: Readable/Writable X: Undefined ## Port 6 pull-up setting register (PUL6) The bits of the pull-up setting register correspond to the pins of port 6 in one-to-one correspondence. When the pull-up resistor is selected by using the pull-up setting register, the pin will be at "H" level (pull-up state) instead of Hi-Z during stop (SPL = 1). During a reset, however, the pull-up is invalid and the pin remains at Hi-Z. Figure 4.6-2 shows the pull-up resistor settings assigned to the values of the bits of the port 6 pull-up setting register. Figure 4.6-2 Pull-up Resistor Settings (PUL6) # 4.6.2 Operations of Port 6 Functions ## This section describes the operation of port 6. ## ■ Operation of Port 6 #### Operation in output port mode When "1" is written for a bit of the DDR6 register, the bit corresponding to a pin of port 6, the pin functions as an output port. In output port mode, the output transistor operation is enabled and the output latch data is output to the pin. Once data has been written into the PDR6 register, the written data is held in the output latch and output to the pin as it is. The value state of the pin can be read by reading the PDR6 register. #### Operation in input port mode When "0" is written for a bit of the DDR6 register, the bit corresponding to a pin of port 6, the pin functions as an input port. In input port mode, the output transistor is OFF and the pin status is Hi-Z. Once data has been written into the PDR6 register, the written data is held in the output latch but is not output to the pin. The value state of the pin can be read by reading the PDR6 register. #### Operation when a reset is performed When the CPU is reset, the bits of the DDR6 register are initialized to "0". Thus, all output transistors become OFF and the pins become Hi-Z. However, CPU resets do not initialize the PDR6 register. If a pin is used as an output port after the reset, reinitialize the PDR6 register to contain new output data in the bit position corresponding to the pin and then set the corresponding bit of the DDR6 register so that the pin will function as an output port. ## Operation in stop mode When the pin state setting bit of the standby control register (STBC: SPL) is "1" and when the stop mode is entered, the output transistor is turned OFF and the pin becomes Hi-Z because the output transistor is forcibly turned OFF without respect to the value existing on the DDR6 register in the bit position corresponding to the pin. Input remains fixed to prevent leaks by input open. Table 4.6-4 summarizes the operating modes of the pins of port 6. Table 4.6-4 Operating Modes of Pins of Port 6 | Pin name | Normal operation, sleep, stop (SPL = 0) | Stop (SPL = 1) | At a reset | |----------|-----------------------------------------|----------------|------------| | P60, P61 | General-purpose I/O port | Hi-Z | Hi-Z | ## Note: When the pull-up resistor is selected by using the pull-up setting register, the pin state will be "H" level instead of Hi-Z in stop mode (SPL=1). During a reset, however, the pull-up is invalid with the pin remaining at Hi-Z. ## 4.7 Port 7 Port 7 is a general-purpose I/O port. This section describes the port function when operating as general-purpose I/O port. This section also describes the port structure, pins, the pin block diagram associated registers of port 7. #### ■ Structure of Port 7 Port 7 comprises the following four elements: - General-purpose I/O pin (P70 to P72) - Port 7 data register (PDR7) - Port 7 data direction register (DDR7) - Port 7 pull-up setting register (PUL7) ## ■ Pins of Port 7 Port 7 has 3 CMOS I/O pin. Table 4.7-1 lists the pins of port 7. Table 4.7-1 Pins of Port 7 | Port name | t name Pin name Functio | | Input and o | utput form | Circuit | |-----------|-------------------------|---------------------|-------------|------------|---------| | Port name | Pin name | Tunction | Input | Output | type | | Port 7 | P70 to P72 | General-purpose I/O | CMOS | CMOS | Е | For circuit type, see Section "1.7 Pin Functions Description " and "1.8 I/O Circuit Types ". ## ■ Block Diagram of Port 7 PDR Stop mode (SPL = 1) PDR read Internal data bus PDR read (when read-modify-write is performed) Pch Output latch PDR write Pin Nch DDR DDR write $\mathcal{H}$ Stop mode (SPL = 1) DDR read PUL read PUL PUL write Figure 4.7-1 Block Diagram of Port 7 ## ■ Registers PDR7, DDR7, and PUL7 of Port 7 Registers PDR7, DDR7, and PUL7 are associated with port 7. The bits of these registers correspond to the pins of port 7 in one-to-one correspondence. Table 4.7-2 tabulates the correspondence between the pins and the bits of the port 7 registers. Table 4.7-2 Correspondence between the Pins and the Bits of the Port 7 Registers | Port name | Bits of as | Bits of associated registers and corresponding pins | | | | | | | | |-----------|--------------------------|-----------------------------------------------------|------|------|------|------|------|------|------| | Port 7 | PDR7, DDR7, PUL7 | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | | Pin corresponding to bit | - | - | - | - | - | P72 | P71 | P70 | # 4.7.1 Registers of Port 7 (PDR7, DDR7, PUL7) ## This section describes the registers associated with port 7. ## **■** Functions of Port 7 Registers #### Port 7 data register (PDR7) The PDR7 register indicates the state of the output latch. For a pin set to function as an output port, the same value ("0" or "1") as the value state of the output pin can be read from this register. If the pin is set to function as an input port, however, its output latch value cannot be read from the register. #### Note: When a bit manipulation instruction (SETB, CLRB) is executed, the output latch values, not the value states of the pins, are read; thus, output latch values, other than those for bits to be manipulated, do not change. ## Port 7 data direction register (DDR7) The DDR7 register sets the I/O direction of each pin per bit. When a bit of the DDR7 corresponding to a pin of port 7 is set to "1", the pin functions as an output port. When the bit is set to "0", the pin functions as an input port. Table 4.7-3 lists the functions of the port 7 registers. Table 4.7-3 Functions of Port 7 Registers | Register name | Data | When being read | When being written | Read/<br>Write | Address | Initial value | | |------------------------------|-------|-------------------------|--------------------------------------------------------------------------------------|----------------|-------------------|------------------|--| | Port 7 data | 0 | Pin state is "L" level. | Output latch of "0" is set and "L" level is output to the pin in output port mode. | | | VVV | | | register (PDR7) | l Pin | Pin state is "H" level. | Output latch of "1" is set and "H" level is output to the pin in output port mode. | N/W | 0063 <sub>H</sub> | XXX <sub>B</sub> | | | Port 7 data | 0 | Input port | Output transistor operation is disabled and the pin is set to serve as an input pin. | D/W | 0064 | 000 | | | direction<br>register (DDR7) | 1 | Output port | Output transistor operation is enabled and the pin is set to serve as output pin. | R/W | 0064 <sub>H</sub> | 000 <sub>B</sub> | | R/W: Readable and Writable X: Undefined ## Port 7 pull-up setting register (PUL7) The bits of the pull-up setting register correspond to the pins of port 7 in one-to-one correspondence. When the pull-up resistor is selected by using the pull-up setting register, the pin will be at "H" level (pull-up state) instead of Hi-Z during stop (SPL = 1). During a reset, however, the pull-up is invalid and the pin remains at Hi-Z. Figure 4.7-2 shows the pull-up resistor settings assigned to the values of the bits of the port 7 pull-up register. Address bit7 bit6 bit5 bit2 bit1 bit0 Initial value bit4 bit3 0065н PUL72 PUL71 PUL70 -----000B R/W R/W R/W PUL70 PUL72 PUL71 0 P72 pull-up OFF P71 pull-up OFF P70 pull-up OFF R/W : Readable/Writable P72 pull-up ON P71 pull-up ON P70 pull-up ON : Initial value Figure 4.7-2 Pull-up Resistor Settings (PUL7) # 4.7.2 Operations of Port 7 Functions ## This section describes the operation of port 7. ## ■ Operation of Port 7 #### Operation in output port mode When "1" is written for a bit of the DDR7 register, the bit corresponding to a pin of port 7, the pin functions as an output port. In output port mode, the output transistor operation is enabled and the output latch data is output to the pin. Once data has been written into the PDR7 register, the written data is held in the output latch and output to the pin as it is. The value state of the pin can be read by reading the PDR7 register. ## Operation in input port mode When "0" is written for a bit of the DDR7 register, the bit corresponding to a pin of port 7, the pin functions as an input port. In input port mode, the output transistor is OFF and the pin status is Hi-Z. Once data has been written into the PDR7 register, the written data is held in the output latch but is not output to the pin. The value state of the pin can be read by reading the PDR7 register. #### Operation when a reset is performed When the CPU is reset, the bits of the DDR7 register are initialized to "0". Thus, all output transistors become OFF and the pins become Hi-Z. However, CPU resets do not initialize the PDR7 register. If a pin is used as an output port after the reset, reinitialize the PDR7 register to contain new output data in the bit position corresponding to the pin and then set the corresponding bit of the DDR7 register so that the pin will function as an output port. #### Operation in stop mode When the pin state setting bit of the standby control register (STBC: SPL) is "1" and when the stop mode is entered, the output transistor is turned OFF and the pin becomes Hi-Z because the output transistor is forcibly turned OFF without respect to the value existing on the DDR7 register in the bit position corresponding to the pin. Input remains fixed to prevent leaks by input open. Table 4.7-4 summarizes the operating modes of the pins of port 7. Table 4.7-4 Operating Modes of Pins of Port 7 | Pin name | Normal operation, sleep, stop (SPL = 0) | Stop (SPL = 1) | At a reset | |------------|-----------------------------------------|----------------|------------| | P70 to P72 | General-purpose I/O port | Hi-Z | Hi-Z | ## Note: When the pull-up resistor is selected by using the pull-up setting register, the pin state will be "H" level instead of Hi-Z in stop mode (SPL=1). During a reset, however, the pull-up is invalid with the pin remaining at Hi-Z. # 4.8 Programming Example of I/O Port This section provides an example of programming with I/O ports. ## ■ I/O Port Programming Example #### Processing specification Ports 0 and 3 are used to light all seven segments of LED (eight segments if the decimal point is included). Pin P00 is connected to the anode common pin of LED and pins P30 to P37 are connected to the pins of the segments. Figure 4.8-1 provides an example of the pins and the 8-segment LED connected. Figure 4.8-1 Example of the Pins and the 8-segment LED Connected ## Coding example | PDR0 EQ<br>DDR0 EQ<br>PDR3 EQ<br>DDR3 EQ | U 0001H<br>U 000CH | ; | Address of port 0 data register Address of port 0 data direction register Address of port 3 data register Address of port 3 data direction register | |------------------------------------------|--------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------| | | EG | | [CODE SEGMENT] | | : | | | | | CL | RB PDR0:0 | ; | Set P00 at "L" level. | | MC | OV PDR3,#11111111B | ; | Set all pins of port 3 at "H" level. | | MO | OV DDR0,#11111111B | ; | Set P00 to function as an output port by coding #XXXXXX1B. | | MO | OV DDR3,#11111111B | ; | Set all bits of DDR3 such that all pins of port 3 function as an output port. | | : | | | • • | | EN . | IDS | | | | ;EN | TD | | | # **CHAPTER 5** # TIME-BASE TIMER This chapter describes the functions and operations of the time-base timer. - 5.1 Overview of Time-base Timer - 5.2 Configuration of Time-base Timer - 5.3 Time-base Timer Control Register (TBTC) - 5.4 Interrupt of Time-base Timer - 5.5 Operations of Time-base Timer Functions - 5.6 Notes on Using Time-base Timer - 5.7 Program Example for Time-base Timer ## 5.1 Overview of Time-base Timer The time-base timer functions as an interval timer. The time-base timer is a 21-bit freerun counter that counts up in synchronization with the internal count clock (at the oscillation frequency divided by 2). The timer also has an interval timer function to select one of four time intervals. In addition, it provides timer output for oscillation stabilization time and an operation clock for the watchdog timer. The time-base timer stops operating in modes in which oscillation stops. #### ■ Interval Timer Function The interval timer function is used to continuously generate interrupts at specified intervals. - An interrupt occurs when the interval timer bits of the time-base timer counter overflow. - One of four time intervals can be selected by setting the interval timer bits. Table 5.1-1 lists the time intervals for the time-base timer. Table 5.1-1 Time Intervals for Time-base Timer | Internal count clock cycle | Time interval | | | |-----------------------------|-----------------------------------------------------------|--|--| | | 2 <sup>13</sup> /F <sub>CH</sub> (Approximately 0.66 ms) | | | | 2/E (0.16 us) | 2 <sup>15</sup> /F <sub>CH</sub> (Approximately 2.6 ms) | | | | 2/F <sub>CH</sub> (0.16 μs) | 2 <sup>18</sup> /F <sub>CH</sub> (Approximately 21.0 ms) | | | | | 2 <sup>22</sup> /F <sub>CH</sub> (Approximately 335.5 ms) | | | F<sub>CH</sub>: Oscillation frequency ## **■ Clock Supply Function** The clock supply function is used to provide one of three timer outputs for the oscillation stabilization wait time and the operation clock for the resource function. Table 5.1-2 lists cycles of the clock that the time-base timer supplies to peripherals. Table 5.1-2 Clock Cycles Supplied by Time-base Timer (1/2) | Clock supplied to | Clock cycle | Remarks | | |--------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--| | | 2 <sup>14</sup> /F <sub>CH</sub> (Approximately 1.31 ms) | Selected by the oscillation stabilization time | | | Oscillation stabilization time | 2 <sup>17</sup> /F <sub>CH</sub> (Approximately 10.49 ms) | selected by the oscillation stabilization time selection bits (SYCC: WT1, WT0) of the clock control section system clock control register. | | | | 2 <sup>18</sup> /F <sub>CH</sub> (Approximately 20.97 ms) | control section system clock control register. | | The values enclosed in parentheses are time intervals when the oscillation frequency is 12.5 MHz. Table 5.1-2 Clock Cycles Supplied by Time-base Timer (2/2) | Clock supplied to | Clock cycle | Remarks | |-------------------|-----------------------------------------------------------|-------------------------------| | Watchdog timer | 2 <sup>22</sup> /F <sub>CH</sub> (Approximately 335.5 ms) | Watchdog timer count up clock | | A/D converter | 2 <sup>8</sup> /F <sub>CH</sub> (Approximately 20.5 μs) | Continuous activation clock | F<sub>CH</sub>: Oscillation frequency The values enclosed in parentheses are time intervals when the oscillation frequency is 12.5 MHz. ## Note: Because oscillation cycles vary immediately after oscillation starts, the oscillation stabilization wait time is listed for reference. # 5.2 Configuration of Time-base Timer The time-base timer consists of the following four function blocks. - Time-base counter - Counter clear circuit - Interval timer selector - Time-base timer control register (TBTC) ## ■ Block Diagram of Time-base Timer Figure 5.2-1 Block Diagram of Time-base Timer #### Time-base timer counter A 21-bit up counter that accepts the oscillation frequency divided by two as the count clock and stops operating when oscillation stops. #### Counter clear circuit Clears the counter when the TBTC register is set (TBR = 0), stop mode is entered (STBC: STP = 1), or a power-on reset occurs. #### Interval timer selector Selects 1 bit for the interval timer from four bits in the time-base counter. When the specified bit overflows, an interrupt occurs. #### Time-base timer control register (TBTC) Selects a time interval, clears the counter, controls interrupts, or checks the status. # 5.3 Time-base Timer Control Register (TBTC) The time-base timer control register (TBTC) selects a time interval, clears the counter, controls interrupts, or checks the status. ## ■ Time-base Timer Control Register (TBTC) Figure 5.3-1 Time-base Timer Control Register (TBTC) Table 5.3-1 Explanation of Functions of Each Bit in Time-base Timer Control Register (TBTC) | | Bit name | Description | | | | | |--------------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | bit7 | TBOF:<br>Overflow interrupt request<br>flag bit | <ul> <li>This bit is set to "1" when the specified bit of the time-base timer counter overflows.</li> <li>An interrupt request is sent when this bit and the interrupt request enable bit (TBIE) are both "1".</li> <li>While this bit is written, it is cleared when "0" is specified, and nothing is changed and affected when "1" is specified.</li> </ul> | | | | | | bit6 | TBIE:<br>Interrupt request enable bit | This bit enables or disables an interrupt request to be output to the CPU. An interrupt request is output when this bit and the overflow interrupt request flag bit (TBOF) are both "1". | | | | | | bit5<br>to<br>bit3 | Unused bits | <ul><li>These bits are undefined when they are read.</li><li>Nothing is affected when they are written.</li></ul> | | | | | | bit2,<br>bit1 | TBC1, TBC0:<br>Time interval selection bits | <ul> <li>These bits specify a time interval for the interval timer.</li> <li>The interval timer bits of the time-base timer counter are specified.</li> <li>One of four time intervals can be selected.</li> </ul> | | | | | | bit0 | TBR: Time-base timer initialization bit | This bit clears the time-base timer counter. The counter is cleared to 000000 <sub>H</sub> when "0" is written to this bit, nothing is changed and affected when "1" is written. Note: This bit is always "1" at the beginning of reading. | | | | | # 5.4 Interrupt of Time-base Timer The time-base timer counter generates an interrupt when the specified bit of the counter overflows (interval timer function). ## ■ Interrupts when the Interval Timer Function is Enabled The counter counts up with the internal count clock. When the specified interval timer bit overflows, the overflow interrupt request flag bit (TBTC: TBOF) is set to "1". Then if the interrupt request enable bit is enabled (TBTC: TBIE = 1), an interrupt request (IRQ7) is sent to the CPU. When this occurs, use the interrupt handling routine and set the TBOF bit to "0" to clear the interrupt request. The TBOF bit is set to "1" when the specified bit overflows regardless of the value of the TBIE bit. #### Note: When the interrupt request is allowed to be output (TBIE = 1) after a reset is released, clear the TBOF bit (TBOF = 0) at the same time. #### Note: - An interrupt request is generated immediately after the TBIE bit is set from 0 (disable) to 1 (enable) if the TBOF bit is "1". - When the counter is cleared (TBTC: TBR = 0) and the specified bit overflows at the same time, the TBOF bit is not set. ## Oscillation Stabilization Time and Time-base Timer Interrupts If a time interval is set the time shorter than the oscillation stabilization time, the interval interrupt request (TBTC: TBOF = 1) is generated from the time-base timer upon the start of normal mode. In this case, interrupts from the time-base timer must be disabled (TBTC: TBIE = 0) when switching to stop mode in which an oscillation is stopped. ## ■ Register and Vector Table Related to Interrupts from Time-base Timer Table 5.4-1 Register and Vector Table Related to Time-base Timer Interrupts | Interrupt name | Interrupt | t level setting req | Address of vector table | | | |----------------|---------------------------|---------------------|-------------------------|-------------------|-------------------| | Interrupt name | Register | Bits to | be set | High-order | Low-order | | IRQ7 | ILR2 (007C <sub>H</sub> ) | L71 (bit7) | L70 (bit6) | FFEC <sub>H</sub> | FFED <sub>H</sub> | See Section "3.4.2 Steps in the Interrupt Operation" for details on interrupt operations. # 5.5 Operations of Time-base Timer Functions The time-base timer functions as an interval timer or supplies clocks to some peripherals. ## Operations of Interval Timer Function (Time-base Timer) To use as an interval timer, the settings shown below must be made. Figure 5.5-1 Setting Interval Timer Function The counter in the time-base timer continues to count up in synchronization with the internal count clock (at the oscillation frequency divided by two) as long as the clock oscillates. The counter counts from "0" upon being cleared (TBR = 0). When the interval timer bit overflows, the overflow interrupt request flag bit (TBOF) is set to "1". In other words, interrupts are generated at specified intervals, starting from when the counter is cleared. ## ■ Operations of Clock Supply Function The time-base timer is often used to make oscillation stabilization wait time. The oscillation stabilization time is measured from when the time-base timer counter is cleared to when the oscillation stabilization bit overflows. One of three oscillation stabilization time can be selected by the oscillation stabilization time selection bits of the system clock control register (SYCC: WT1, WT0). The time-base timer supplies clocks to the watchdog timer and A/D converter. Clearing the time-base timer counter affects the operation of continuous activation cycles. In addition, when the time-base timer is cleared, the counter in the watchdog timer is also cleared. ## **■** Operations of Time-base Timer Figure 5.5-2 shows the operation of the time-base timer when: - power-on reset occurs. - sleep mode is entered while the interval timer function is being performed in normal mode. - stop mode is entered. - a counter clear request is generated. In stop mode, the time-base timer is cleared and stops operating. When returning from stop mode, the time-base timer counts the oscillation stabilization time. Figure 5.5-2 Operations of Time-base Timer # 5.6 Notes on Using Time-base Timer ## Notes on using the time-base timer are shown below. ## ■ Notes on Using Time-base Timer #### Notes on using programs to set time-base timer When the interrupt request flag bit (TBTC: TBOF) is "1" and the interrupt request enable bit is enabled (TBTC: TBIE = 1), a return from interrupt handling is not possible. The TBOF bit must be cleared. #### Clearing time-base timer The time-base timer is cleared when the time-base timer initialization bit is set to 0 (TBTC: TBR = 0) or when the oscillation stabilization time is required. Because the time-base timer is used as the count clock for the watchdog timer, clearing the time-base timer also clears the watchdog timer. #### Using time-base timer as oscillation stabilization time timer Oscillation has not yet started in stop mode or when the power is turned on. Therefore, the time-base timer makes oscillation stabilization wait time after the resonator starts operating. The appropriate oscillation stabilization time must be selected according to the type of resonator connected to the resonator (clock generator). See Section "3.6.1 Clock Generator ". #### Notes on peripheral functions the time-base timer supplies to the clock When entering the modes in which oscillation stops, the counter is cleared and the time-base timer stops operating. The clock from the time-base timer may have a shorter "H" level period or longer "L" level period (up to half the clock cycle) when the counter of the time-base timer is cleared because the clock starts operating from the initial state. The clock for the watchdog timer also starts operating from the initial state, but the watchdog timer operates at a normal cycle because the watchdog timer counter is cleared at the same time. # 5.7 Program Example for Time-base Timer ## Programming examples for the time-base timer are shown below. ## **■** Programming Examples for Time-base Timer ## Processing specification Repeatedly generate an interval timer interrupt at intervals of $2^{18}/F_{CH}$ (F<sub>CH</sub>: oscillation frequency). The time interval is approximately 21.0 ms (operating at 12.5 MHz). ## Coding examples | y examples | | | | | |---------------|-------------|-------------------------|-------|---------------------------------------------------------------------------| | TBTC | EQU | 0000AH | ; | Address of time-base timer control register | | TBOF | EQU | TBTC:7 | ; | Definition of interrupt request flag bit | | ILR2 | EQU | 007CH | ; | Address of interrupt level setting register 2 | | INT_V | DSEG<br>ORG | ABS<br>0FFECH | ; | [DATA SEGMENT] | | IRQ7<br>INT_V | DW | WARI | ; | Setting interrupt vector | | ; | N | Main program | | | | • | CSEG | 1 6 | | [CODE SEGMENT] | | | | | ; | Stack pointer (SP) or other registers are assumed to | | | | | | have been initialized. | | | : | | | | | | CLRI | | ; | Interrupt disable | | | MOV | ILR2,#01111111B | | Setting interrupt level (level 1) | | | MOV | TBTC,#01000100B | ; | | | | | | | request output, selecting 2 <sup>18</sup> /F <sub>CH</sub> , and clearing | | | | | | time-base timer | | | SETI | | | | | | SEII | | , | Interrupt enable | | | | ntarrunt processing rou | ıtina | e | | WARI | CLRB | TBOF | | Clearing interrupt request flag | | William | PUSHW | | , | clearing interrupt request riag | | | XCHW | | | | | | PUSHW | • | | | | | : | 11 | | | | | User prod | ressing. | | | | | : | | | | | | POPW | A | | | | | XCHW | A, T | | | | | | • | | | ## CHAPTER 5 TIME-BASE TIMER | | POPW | A | | | |---|-------------|---|------|--| | | RETI | | | | | | <b>ENDS</b> | | | | | | | | <br> | | | , | END | | | | # **CHAPTER 6** # **WATCHDOG TIMER** This chapter describes the functions and operations of the watchdog timer. - 6.1 Overview of Watchdog Timer - 6.2 Configuration of Watchdog Timer - 6.3 Watchdog Control Register (WDTC) - 6.4 Operations of Watchdog Timer Functions - 6.5 Notes on Using Watchdog Timer - 6.6 Program Example for Watchdog Timer # 6.1 Overview of Watchdog Timer The watchdog timer is a 1-bit counter that uses output from the time-base timer, based on oscillation frequency, as the count clock. The watchdog timer resets the CPU when not cleared within a specified period after activation. ## ■ Watchdog Timer Function The watchdog timer is a counter for preventing programs from hanging up. The timer must be cleared at specified intervals after being activated. If the timer is not cleared within a specified period of time because, for example, a program goes into an endless loop, the timer sends to the CPU a watchdog reset having a period of four instruction cycles. The watchdog timer uses the output from the time-base timer as the count clock. The time intervals for the watchdog timer are listed in Table 6.1-1. When the watchdog timer is not cleared, a watchdog reset occurs following the time between the minimum time interval and the maximum time interval. The counter must be cleared before the time of the minimum time interval. Table 6.1-1 Watchdog Timer Time Intervals | | Count clock | | | |-----------------------|----------------------------------------------------------|--|--| | | Time-base timer output (Oscillation frequency: 12.5 MHz) | | | | Minimum time interval | Approximately 335.5 ms * | | | | Maximum time interval | Approximately 671.0 ms | | | <sup>\*: (</sup>number of counts of time-base timer $(2^{22})$ ) × (oscillation frequency $(F_{CH})$ divided by 2) See Section "6.4 Operations of Watchdog Timer Functions" for details on the maximum and minimum time intervals of the watchdog timer. #### **Notes:** - The watchdog timer counter is cleared when the time-base counter is cleared (TBTC: TBR = 0) while output from the time-base timer is selected. Therefore, if the time-base timer counter supplying the count clock is cleared repeatedly within the time interval of the watchdog timer, the watchdog timer does not function correctly. - When switching to sleep or stop mode, the watchdog timer counter is cleared and stops operating until returning to normal operation (RUN state). # 6.2 Configuration of Watchdog Timer The watchdog timer consists of the following four function blocks. - Watchdog timer counter - Reset control circuit - Counter clear control circuit - Watchdog control register (WDTC) ### ■ Block Diagram of Watchdog Timer Figure 6.2-1 Block Diagram of Watchdog Timer Watchdog timer counter (1-bit counter) A 1-bit counter that operates by accepting output from the time-base timer as the count clock. Reset control circuit Sends the reset signal to the CPU when the watchdog timer counter overflows. Counter clear control circuit Controls the clearing and stopping of the watchdog timer counter. Watchdog control register (WDTC) Activates and clears the watchdog timer counter. Because this register is write-only, bit manipulation instructions cannot be used. # 6.3 Watchdog Control Register (WDTC) The watchdog control register (WDTC) activates and clears the watchdog timer. # ■ Watchdog Control Register (WDTC) Address bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 Initial value 0009H RESV WTE3 WTE2 WTE1 WTE0 0---XXXXB R/W R/W R/W R/W WTE3|WTE2|WTE1|WTE0 Watchdog control bit Starts the watchdog timer (upon first writing after reset) 0 0 1 1 Clears the watchdog timer (upon second or subsequent writing after a reset) Other than above No operation RESV Reserved bit Write "0" to this bit. R/W: Readable/writable : Unused : Undefined Figure 6.3-1 Watchdog Control Register (WDTC) Table 6.3-1 Explanation of Functions of Each Bit in Watchdog Control Register (WDTC) | Bit name | | Description | | |--------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | bit7 | RESV: Reserved bit | • Write "0" to this bit. | | | bit6<br>to<br>bit4 | Unused bits | <ul><li> Undefined when it is read.</li><li> Writing values does not affect operation.</li></ul> | | | bit3<br>to<br>bit0 | WTE3, WTE2,<br>WTE1, WTE0:<br>Watchdog control bits | Writing "0101 <sub>B</sub> " activates (for first writing) or clears (for second or subsequent writing) the watchdog timer. Writing other than "0101 <sub>B</sub> " does not affect operation. Note: These bits indicate "1111 <sub>B</sub> " when read. Bit manipulation instructions cannot be used. | | # 6.4 Operations of Watchdog Timer Functions The watchdog timer generates a watchdog reset when the watchdog timer counter overflows. ### Operations of Watchdog Timer #### Activating watchdog timer The watchdog timer is activated when the first time " $0101_B$ " is written to the watchdog control bits (WDTC: WTE3 to WTE0) of the watchdog control register. The watchdog timer cannot be stopped without accepting a reset upon activation. #### Clearing watchdog timer The watchdog timer counter is cleared the second or subsequent time " $0101_B$ " is written to the watchdog control bits (WDTC: WTE3 to WTE0) of the watchdog control register. When the counter is not cleared within the time interval of the watchdog timer, the counter overflows and the timer generates the internal reset signal having a period of four instruction cycles. #### Time intervals of watchdog timer The time interval varies depending on the timing at which the watchdog timer is cleared. Figure 6.4-1 shows the relationship between the clear timings and time intervals of the watchdog timer when output from the time-base timer is used as the count clock (oscillation frequency: 12.5 MHz). Figure 6.4-1 Clearing Watchdog Timer and Time Interval # 6.5 Notes on Using Watchdog Timer # Notes on using the watchdog timer are provided below. # ■ Notes on Using Watchdog Timer #### Stopping watchdog timer The watchdog timer cannot be stopped without accepting a reset upon activation. ### Clearing watchdog timer Clearing the time-base timer counter that supplies the count clock to the watchdog timer also clears the watchdog timer counter at the same time. Switching to sleep or stop mode clears the watchdog timer counter. ### Notes on creating programs When creating a program that repeatedly clears the watchdog timer in the main loop, ensure that the time necessary for main loop processing, including interrupt handling, is shorter than the minimum time interval of the watchdog timer. # 6.6 Program Example for Watchdog Timer # Programming examples for the watchdog timer are provided below. # ■ Programming Examples of Watchdog Timer - Processing specification - Activate the watchdog timer immediately after the program starts. - Clear the watchdog timer whenever the loop of the main program is run. - Ensure that the time necessary for running the main loop once, including interrupt handling, is shorter than the minimum time interval (approximately 335.5 ms: operating at 12.5 MHz) of the watchdog timer. ### Coding example ``` WDTC EQU 0009H Address of watchdog control register WDT CLR EQU 00000101B VECT DSEG ABS [DATA SEGMENT] ORG OFFFEH RST V DW PROG Setting reset vector VECT ENDS ;------Main program------ CSEG ; [CODE SEGMENT] PROG Initialization routine upon reset MOVW ; Setting initial value of stack pointer (for interrupt) SP,#0280H Initializing interrupt or other peripheral functions INIT MOV WDTC,#WDT_CLR ; Activating watchdog timer WDTC,#WDT CLR ; Clearing watchdog timer MAIN MOV User processing (interrupt may occur in this processing.) JMP MAIN ; Ensure that the time necessary for running the loop is shorter than the minimum time interval of the watchdog timer. ENDS END ``` # CHAPTER 6 WATCHDOG TIMER # CHAPTER 7 # 8-BIT PWM TIMER This chapter describes the functions and operations of 8-bit PWM timer. - 7.1 Overview of 8-bit PWM Timer - 7.2 Configuration of 8-bit PWM Timer - 7.3 Pin of 8-bit PWM Timer - 7.4 Registers of 8-bit PWM Timer - 7.5 Interrupt of 8-bit PWM Timer - 7.6 Operations of the Interval Timer Functions - 7.7 Operations of the 8-bit PWM Timer Functions - 7.8 States in Each Mode During Operation - 7.9 Notes on Using 8-bit PWM Timer - 7.10 Program Example for PWM Timer # 7.1 Overview of 8-bit PWM Timer An 8-bit PWM timer has the interval timer functions and the PWM timer functions of an 8-bit resolution. A counter is incremented using interval timer functions in synchronization with three types of internal count clocks or the output of 8/16-bit capture timer/counter. The user can select one of these functions. Therefore, the 8-bit interval timer can be set and the square wave of any frequency can be output using the set output. In addition, if a low-pass filter is connected to the PWM output, the D/A converter can be used. ## ■ Interval Timer Functions (Functions to Output the Square Wave) Interrupts are generated repeatedly at any interval by the interval timer functions. Because the output level of the pin (P50/PWM pin) can be inverted for each interrupt, the square wave of any frequency can also be output. - An interval timer operation from the cycle of the count clock to 2<sup>8</sup>-times cycle is possible. - The count clock can be selected from four types. Table 7.1-1 shows the range of intervals and square wave output. Table 7.1-1 Range of Intervals and Square Wave Output | | Count clock cycle | | Interval | Square wave output (Hz) | |---|----------------------|----------------------|-----------------------------------------------------------------------|----------------------------------------------| | 1 | | 1t <sub>INST</sub> | $1t_{INST}$ to $2^8t_{INST}$ | $1/(2t_{INST})$ to $1/(2^9t_{INST})$ | | 2 | Internal count clock | 16t <sub>INST</sub> | 2 <sup>4</sup> t <sub>INST</sub> to 2 <sup>12</sup> t <sub>INST</sub> | $1/(2^{5}t_{INST})$ to $1/(2^{13}t_{INST})$ | | 3 | | 64t <sub>INST</sub> | 2 <sup>6</sup> t <sub>INST</sub> to 2 <sup>14</sup> t <sub>INST</sub> | $1/(2^{7}t_{INST})$ to $1/(2^{15}t_{INST})$ | | | | 2t <sub>INST</sub> | 2t <sub>INST</sub> to 2 <sup>17</sup> t <sub>INST</sub> | $1/(2^2 t_{INST})$ to $1/(2^{10} t_{INST})$ | | 4 | 8/16-bit timer | 32t <sub>INST</sub> | 2 <sup>5</sup> t <sub>INST</sub> to 2 <sup>21</sup> t <sub>INST</sub> | $1/(2^6 t_{INST})$ to $1/(2^{14} t_{INST})$ | | 4 | count clock | 512t <sub>INST</sub> | 29t <sub>INST</sub> to 2 <sup>25</sup> t <sub>INST</sub> | $1/(2^{10}t_{INST})$ to $1/(2^{18}t_{INST})$ | | | | 1t <sub>EXT</sub> | 1t <sub>EXT</sub> to 2 <sup>16</sup> t <sub>EXT</sub> | $1/(2t_{EXT})$ to $1/(2^9t_{EXT})$ | $t_{INST}$ : Instruction cycle (Affected by the clock mode and others.) t<sub>EXT</sub>: Output cycle of an 8/16-bit capture timer #### Note: Calculation example of intervals and square wave frequency The following expression is the interval when the count clock cycle is set to 1 $t_{INST}$ and when an oscillation frequency ( $F_{CH}$ ) of 12.5 MHz and a PWM compare register (COMR) value of $DD_H$ (221) are set. Another expression is the frequency of the square wave output from the PWM pin that is operated continuously without changing the COMR register value. However, the values are true when the maximum speed clock of the normal mode is selected (CS1, $CS0 = 11_B$ , 1 instruction cycle = $4/F_{CH}$ ) with the system clock control register (SYCC). Interval $$= (1 \quad 4/F_{CH}) \quad (COMR \text{ register value} + 1)$$ $$= (4/12.5 \text{ MHz}) \quad (221 + 1)$$ $$= 71.0 \quad \text{s}$$ Output frequency = $F_{CH} / (1 \quad 8 \quad (COMR \text{ register value} + 1))$ $$= 12.5 \text{ MHz} / (8 \quad (221 + 1))$$ $$\stackrel{.}{=} 7.04 \text{ kHz}$$ #### **■ PWM Timer Functions** The PWM timer functions have an 8-bit resolution and can control the "H" level width and "L" level width of one cycle. Because the resolution is 1/256, a pulse can be output at a duty ratio of 0 to 99.6%. The frequency of the PWM wave can be selected from four types. The low-pass filter can be connected to the output and used as the D/A converter. Table 7.1-2 shows the frequency of the PWM wave that can be set by PWM timer functions. Figure 7.1-1 is a configuration example of the D/A converter. Table 7.1-2 Frequencies of the PWM Wave that can be Set by the PWM Timer Functions | | 1 | 2 | 3 | | 4 | 4 | | |-------------------|----------------------------------|-----------------------------------|---------------------------------------------|----------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------|------------------------------------------------| | | Internal clock | | Output of an 8/16-bit capture timer/counter | | | | | | Count clock cycle | 1t <sub>INST</sub> | 16t <sub>INST</sub> | 64t <sub>INST</sub> | $2^2 t_{INST}$ to $2^{10} t_{INST}$ | $2^6 t_{INST}$ to $2^{14} t_{INST}$ | $2^{10}$ t <sub>INST</sub> to $2^{18}$ t <sub>INST</sub> | $1t_{\mathrm{EXT}}$ to $2^{8}t_{\mathrm{EXT}}$ | | PWM wave cycle | 2 <sup>8</sup> t <sub>INST</sub> | 2 <sup>12</sup> t <sub>INST</sub> | 2 <sup>14</sup> t <sub>INST</sub> | $2^{10}$ t <sub>INST</sub> to $2^{18}$ t <sub>INST</sub> | $2^{14}$ t <sub>INST</sub> to $2^{22}$ t <sub>INST</sub> | $2^{18}$ t <sub>INST</sub> to $2^{26}$ t <sub>INST</sub> | $2^8 t_{\rm EXT}$ to $2^{16} t_{\rm EXT}$ | t<sub>INST</sub>: Instruction cycle (Affected by the clock mode and others.) t<sub>EXT</sub>: Output frequency of an 8/16-bit capture timer Figure 7.1-1 Configuration Example of the D/A Converter with the PWM Output and a Low-Pass Filter #### Note: While PWM timer functions are enabled, no interrupt request occurs. # 7.2 Configuration of 8-bit PWM Timer An 8-bit PWM timer consists of the following six blocks. - Count clock selector - 8-bit counter - Comparator - PWM generation and output control circuit - PWM compare register (COMR) - PWM control register (CNTR) ## ■ Block Diagram of an 8-bit PWM Timer Figure 7.2-1 Block Diagram of an 8-bit PWM Timer #### Count clock selector The count clock selector selects one of three types of internal counter clock. The selector also selects an 8/16-bit capture timer or counter and uses it to increment the count of the 8-bit counter. #### 8-bit counter This counter is incremented by the count clock selected by the count clock selector. #### Comparator A latch in the comparator holds the COMR register value when the value of the 8-bit counter is $00_H$ and then compares the 8-bit counter with the COMR register value latched and detects a match. #### PWM generation circuit and PWM output control circuit During the interval timer operation, once a match is detected, an interrupt request occurs. And when the bit to control the output pin (CNTR: OE) is "1", the output level of the P50/PWM pin is inverted by the output control circuit, at which time the 8-bit counter is cleared. During the PWM timer operation, once a match is detected, the output level of the P50/PWM pin is changed from "H" level to "L" level by the PWM generation circuit. Thereafter, when the 8-bit counter overflows, the output level is returned to "H" level. #### COMR register This register is used to set a value for comparison with the counter value of the 8-bit counter. #### CNTR register This register is used to select the operation mode, enable and disable operations, set the count clock, control interrupts, and check status. When the operation mode is the PWM timer mode (P/TX = 0), the 8-bit counter cannot be cleared (by the match detection signal from the comparator) and the interrupt request (IRQ9) is disabled. # 7.3 Pin of 8-bit PWM Timer This section describes the pin and provides a block diagram of the pin related to the 8-bit PWM timer. #### ■ Pin Related to the 8-bit PWM Timer The pin related to the 8-bit PWM timer is the P50/PWM pin. #### • P50/PWM pin This pin can be used as a general-purpose I/O port (P50) and for output of the interval timer or PWM timer (PWM). #### PWM: While the pin functions as the interval timer, the square wave is output to the pin. While the pin functions as the PWM timer, the PWM wave is output to the pin. When the bit to control the output pin is set to the dedicated pin (CNTR: OE = 1), the P50/PWM pin automatically functions as an output pin, regardless of the value of the port 5 data direction register (DDR5: bit0), and as the PWM pin. ### ■ Block Diagram of the Pin Related to the 8-bit PWM Timer Figure 7.3-1 Block Diagram of the Pin Related to the 8-bit PWM Timer # 7.4 Registers of 8-bit PWM Timer This section describes the registers related to the 8-bit PWM timer. ### ■ Registers Related to the 8-bit PWM Timer Figure 7.4-1 Registers Related to the 8-bit PWM Timer #### Note: Because the PWM compare register (COMR) is a write-only register, an instruction to operate bits cannot be used. #### 7.4.1 **PWM Control Register (CNTR)** The PWM control register (CNTR) is used to select the operation mode (interval timer operation or PWM timer operation) of the 8-bit PWM timer, switch the resolution of the PWM timer functions, and select the count clock. ### **■ PWM Control Register (CNTR)** Figure 7.4-2 PWM Control Register (CNTR) Table 7.4-1 Explanation of the Functions of Each Bit in the PWM Control Register (CNTR) | Bit name | | Function | |---------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | P/TX:<br>Bit to select the<br>operation mode | This bit is used to select the interval timer operation (P/TX = 0) or PWM timer operation (P/TX = 1). Note: Before writing into this bit, stop the counter operation (TPE = 0), disable an interrupt (TIE = 0), and clear the interrupt request flag bit (TIR = 0). | | bit6 | Unused bit | The value during a read is undetermined. A write does not affect operations. | | bit5,<br>bit4 | P1, P0:<br>Bits to select the clock | This bit is used to select the count clock of the interval timer functions or PWM timer functions. One of three types of internal count clock or the output of the 8/16-bit capture timer or counter can be selected. Note: When the counter is operating (TPE = 1), do not switch P1 and P0. | | bit3 | TPE: Bit to enable the counter operation | This bit is used to start and stop the interval timer functions or PWM timer functions. To start the count operation, write "1" to this bit. When "0" is written to this bit, the counter is cleared (setting $00_{\rm H}$ ) and then stopped. | | bit2 | TIR:<br>Interrupt request flag bit | While the internal timer functions are enabled: When the counter value matches the PWM compare register (COMR) value, "1" is set to this bit. When this bit and the bit to enable an interrupt request (TIE) are "1", an interrupt request to the CPU is output. While the PWM timer functions are enabled, an interrupt request does not occur. When this bit is written, it is cleared (setting "0"). Writing "1" does not affect this bit in any way. | | bit1 | OE: Bit to control the output pin | When this bit is "0", the P50/PWM pin is used as a general-purpose port (P50). When the bit is "1", it is used as a dedicated pin (PWM). When the interval timer functions are enabled, the square wave is output to the PWM pin. When the PWM timer functions are enabled, the PWM wave is output to the PWM pin. | | bit0 | TIE:<br>Bit to enable an interrupt<br>request | This bit is used to enable and disable the output of an interrupt request to the CPU. When this bit and the interrupt request flag bit (TIR) are both "1", an interrupt request is output. | # 7.4.2 PWM Compare Register (COMR) The PWM compare register (COMR) is used to set an interval while the internal timer functions are enabled. In addition, the register becomes the "H" level width of a pulse while the PWM timer functions are enabled. # **■ PWM Compare Register (COMR)** Figure 7.4-3 shows the bit configuration of a PWM compare register. Because this register is a write-only register, an instruction to operate bits cannot be used. Figure 7.4-3 PWM Compare Register (COMR) #### While the interval timer is operating: Specify an interval in the register to which the value compared with the counter value is to be set. When the settings written to this register match the counter value, the counter is cleared and "1" is set to the interrupt request flag bit (CNTR: TIR = 1). If a value is written to the COMR register while the counter is operating, the value takes effect at the next cycle (after detection of a match). #### Note: The settings of the COMR register, while the interval timer is operating, can be calculated using the following formula. The gear function, however, affects the instruction cycle. COMR register value = interval/(count clock cycle × instruction cycle) - 1 #### While the PWM timer is operating: Specify the "H" level width of a pulse in the register to which the value that is compared with the counter value is to be set. Until the settings written to this register match the counter value, "H" is output from the PWM pin. When a match is found, "L" is output until the counter value overflows. If a value is written to the COMR register while the counter is operating, the value takes effect at the next cycle (after overflow). #### Note: The settings and cycle of the COMR register, while the PWM timer is operating, can be calculated using the following formula. The gear function, however, affects the instruction cycle. COMR register value = duty ratio (%) $\times$ 256 PWM wave cycle = count clock cycle $\times$ instruction cycle $\times$ 256 # 7.5 Interrupt of 8-bit PWM Timer An interrupt factor of an 8-bit PWM timer can be a match between the counter value and the PWM compare register value while interval timer functions are operating. While the PWM timer functions are enabled, an interrupt request does not occur. ### ■ Interrupts while Interval Timer Functions are Enabled When the counter value is incremented from $00_{\rm H}$ using the selected count clock and matches the PWM compare register (COMR) value, "1" is set to the corresponding interrupt request flag bit (CNTR: TIR). At this time, if the bit to enable an interrupt request is enabled (CNTR: TIE = 1), an interrupt request (IRQ9) to the CPU occurs. Write "0" to the TIR bit using the interrupt handling routine to clear the interrupt request. The TIR bit is set to "1" when the counter value matches the settings regardless of the value of the TIE bit. #### Note: When a match is found between the counter value and the COMR register value concurrently with the stop of the counter (CNTR: TPE = 0), the TIR bit is not set. When the TIR bit is "1", if the TIE bit is changed from disabled to enabled (changed from "0" to "1"), an interrupt request occurs immediately. ## ■ Register and Vector Table Related to the Interrupts of an 8-bit PWM Timer Table 7.5-1 Register and Vector Table Related to the Interrupts of an 8-bit PWM Timer | Interrupt | Interi | rupt level setting reg | Address of vector table | | | |-----------|--------------------------|------------------------|-------------------------|-------------------|-------------------| | name | Register | Bits to | be set | High-order | Low-order | | IRQ9 | ILR3(007D <sub>H</sub> ) | L91(bit3) | L90(bit2) | FFE8 <sub>H</sub> | FFE9 <sub>H</sub> | See Section "3.4.2 Steps in the Interrupt Operation " for interrupt operations. # 7.6 Operations of the Interval Timer Functions This section describes the operations of the interval timer functions of an 8-bit PWM timer. ### Operations of the Interval Timer Functions To make an 8-bit PWM timer operate as an interval timer, set registers as shown in Figure 7.6-1. Figure 7.6-1 Setting Interval Timer Functions When the counter is activated, the counter is incremented from $00_H$ at the start-up of the selected count clock. When the counter value matches the value set in the COMR register (comparison value), the timer inverts the level of the PWM pin, clears the counter, sets the interrupt request flag bit (CNTR: TIR = 1), and starts incrementing again from $00_H$ at the next start-up of the count clock. Figure 7.6-2 shows the operations of an 8-bit PWM timer. Figure 7.6-2 Operations of an 8-bit PWM Timer #### **Notes:** - While interval timer functions are enabled (CNTR: TPE = 1), do not change the count clock cycle (CNTR: P1, P0). - When 00<sub>H</sub> is set to the COMR register, the output of the PWM pin is inverted in the cycle of the count clock. While interval timer functions are enabled, the output level of the PWM pin in the counter stop state (CNTR: TPE = 0) is at "L" level. # 7.7 Operations of the 8-bit PWM Timer Functions This section describes the operations of the 8-bit PWM timer functions. # ■ Operations of the 8-bit PWM Timer Functions To enable 8-bit PWM timer functions, set registers as shown in Figure 7.7-1. Figure 7.7-1 Setting 8-bit PWM Timer Functions When the counter is activated, the counter is incremented from $00_H$ at the start-up of the selected count clock. The output (PWM waveform) of the PWM pin is "H" until a match between the counter value and the value set in the COMR register is found. Once a match is found, the output is "L" until the counter value overflows (FF<sub>H</sub> $\rightarrow 00_H$ ). Figure 7.7-2 shows the PWM waveform output to the PWM pin. Figure 7.7-2 Output Example of the PWM Waveform of 8-bit PWM Timer Functions #### **Notes:** - While PWM timer functions are enabled (CNTR: TPE = 1), do not change the count clock cycle (CNTR: P1, P0). - While PWM timer functions are enabled, the level immediately before the stop is held as the output level of the PWM pin in the counter stop state (CNTR: TPE = 0). # 7.8 States in Each Mode During Operation This section describes the operations for a move to the sleep mode, a move to the stop mode, and the occurrence of a suspend request during the operation of an 8-bit PWM timer. # ■ Operations in the Standby Mode and at a Suspension When the mode is moved to sleep and stop modes, and when a suspend request occurs, the counter value status in which interval timer functions are enabled is shown in the Figure 7.8-1, and the counter value status in which PWM timer functions are enabled is shown in the Figure 7.8-2. When switched to the stop mode, the counter holds a value and stops. When the stop mode is released by an external interrupt, the counter starts operation from the held value. Therefore, the first interval and the first cycle of the PWM waveform are not the values that are set. After the release of the stop mode, initialize the 8-bit PWM timer. While interval timer functions are enabled: Figure 7.8-1 Operation of the Counter in the Standby Mode and during Suspension (while Interval Functions are Enabled) <sup>153</sup> While PWM timer functions are enabled: Figure 7.8-2 Operation in the Standby Mode and during Suspension (while PWM Timer Functions are Enabled) # 7.9 Notes on Using 8-bit PWM Timer This section provides notes on using 8-bit PWM timer. # ■ Notes on Using 8-bit PWM Timer #### Error The activation of the counter by a program does not synchronize the start of an increment by the selected count clock. Therefore, as an error until a match between the counter value and the PWM compare register (COMR) value is detected, the time may be shortened by up to one cycle of the count clock cycle. Figure 7.9-1 shows an error until the count operation is started. Counter value 00<sub>H</sub> 01<sub>H</sub> 02<sub>H</sub> 03<sub>H</sub> 04<sub>H</sub> Count clock One cycle Error Cycle of 00<sub>H</sub> Activating the counter Figure 7.9-1 Error until the Count Operation is Started #### Notes on setting by a program - While interval timer functions or PWM timer functions are enabled (CNTR: TPE = 1), do not change the count clock cycle (CNTR: P1, P0). - If the user wants to switch between the interval timer function and the PWM timer function (CNTR: P/TX), proceed when the counter is stopped (CNTR: TPE = 0), interrupts are disabled (CNTR: TIE = 0), and interrupt requests are cleared (CNTR: TIR = 0). - When the interrupt request flag bit (CNTR: TIR) is "1" and the bit to enable an interrupt request is enabled (CNTR: TIE = 1), recovery from interrupt handling is no longer possible. The TIR bit must be cleared. - When the counter value matches the COMR register value concurrently with the counter stop (CNTR: TPE = 0), the TIR bit is not set. - Depending on how to set TPE, P/TX, and OE, the PWM output waveform varies as shown below. Be careful when using a program to set TPE, P/TX, and OE. - (1) When TPE, P/TX, and OE are set at the same time: MOV CNTR, #11001010B; Starts PWM operations, internal clocks, and count operations. ; Enables the PWM output. (2) When OE is set after TPE and P/TX are set: MOV CNTR, #11001000B; Starts PWM operations, internal clocks, and count operations. MOV CNTR, $\#110010\underline{1}0B$ ; Enables PWM output. Check # 7.10 Program Example for PWM Timer This section describes program examples of an 8-bit PWM timer. # ■ Program Example of Interval Timer Functions PUSHW - Processing specifications - 5 ms interval timer interrupts occur repeatedly. - The square waveform that inverts at an interval is output to the P50/PWM pin. - The following expression yields the COMR register value for which the interval is about 5 ms when the top speed of the gear (one instruction cycle = $4/F_{CH}$ ) is obtained at an oscillation frequency of 12.5 MHz. The count clock is $64 t_{INST}$ of the internal count clock. COMR register value = $5 \text{ ms/}(64 \times 4/12.5 \text{ MHz}) - 1 = 244.1 (0\text{F4}_{\text{H}})$ ### Coding example | CNTR COMR TPE TIR ILR3 INT_V | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>DSEG<br>ORG | 0022H<br>0023H<br>CNTR:3<br>CNTR:2<br>007D<br>ABS<br>0FFF8H | ; | Address of the PWM control register Address of the PWM compare register Defining the bit to enable the counter operation Defining the interrupt request flag bit Address of the register to set the interrupt level [DATA SEGMENT] | |------------------------------|------------------------------------------------|-------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IRQ9 | DW | WARI1 | ; | Setting the interrupt vector | | | ENDS | | | | | ; | | Main program | | (CODE CECUMENT) | | | CSEG | | ; | [CODE SEGMENT] The steel resister (SD) and others are assumed to have | | | | | , | The stack pointer (SP) and others are assumed to have been initialized. | | | : | | | occi inicianzed. | | | CLRI | | ; | Disabling interrupts | | | CLRB | TPE | ; | Stopping the counter operation | | | MOV | ILR3,#11110111B | ; | Setting the interrupt level (level 1) | | | MOV | COMR,#0F4H | ; | Comparison value with the counter value (interval) | | | MOV | CNTR,#00101011B | ; | Enabling the output of the PWM | | | | | ; | Interval timer operation, selection of $64 t_{INST}$ | | | | | ; | Starting the counter operation and enabling the output | | | | | | of interrupt requests | | | SETI | | ; | Enabling interrupts | | | : | | | | | | | 1 1 0 | | | | WARI1 | CLRB<br>PUSHW | TIR<br>A | ; | Clearing the interrupt request flag | | | XCHW | A,T | | Saving A and T | | | 21C11 VV | 11,1 | , | Saving 11 and 1 | # CHAPTER 7 8-BIT PWM TIMER : User processing : POPW A XCHW A,T ; Restoring A and T POPW A RETI ENDS # **■ Program Example of PWM Timer Functions** ### Processing specifications - A PWM wave with a duty ratio of 50% is generated. The duty ratio is then changed to 25%. - No interrupt occurs. - When the count clock is $16 \, t_{INST}$ of an internal count clock, the cycle of the PWM wave is $16 \times 4/12.5$ MHz $\times 256 = 1.3107$ ms, which occurs when the top speed of the gear (one instruction cycle = $4/F_{CH}$ ) is obtained at an oscillation frequency of 12.5 MHz. - The COMR register value with a duty ratio of 50% is shown below. $COMR \ register \ value = 50/100 \times 256 = 128 \ (080_H)$ ### Coding example | CNTR | EQU | 0022H | ; | Address of the PWM control register | |------|------|-----------------|---|----------------------------------------------------------------------------------| | COMR | EQU | 0023H | ; | Address of the PWM compare register | | TPE | EQU | CNTR:3 | ; | Defining the bit to enable the counter operation | | ; | | Main program | | | | | CSEG | | ; | [CODE SEGMENT] | | | : | | | | | | CLRB | TPE | ; | Stopping the counter operation | | | MOV | COMR,#80H | ; | Specification of the H-level width of a pulse, 50% duty ratio | | | MOV | CNTR,#10011010B | ; | PWM timer operation, selection of 16 t <sub>INST</sub> | | | | | ; | Starting the counter operation, clearing the interrupt request flag | | | | | ; | Enabling the output of the PWM pin, disabling the output of interrupt requests | | | : | | | | | | : | | | | | | MOV | COMR,#40H | ; | Changing the duty ratio to 25% (Takes effect at the next cycle of the PWM wave.) | | | : | | | | | • | ENDS | | | | | ,= | END | | | | # CHAPTER 7 8-BIT PWM TIMER # **CHAPTER 8** # 8/16-BIT CAPTURE TIMER/ COUNTER This chapter describes the functions and operation of the 8/16-bit capture timer/counter. - 8.1 Overview of 8/16-bit Capture Timer/Counter - 8.2 Configuration of 8/16-bit Capture Timer/Counter - 8.3 Pins of 8/16-bit Capture Timer/Counter - 8.4 Registers of 8/16-bit Capture Timer/Counter - 8.5 8/16-bit Capture Timer/Counter of Interrupts - 8.6 Explanation of Operations of Interval Timer Functions - 8.7 Operation of Counter Functions - 8.8 Functions of Operations of Capture Functions - 8.9 8/16-bit Capture Timer/Counter Operation in Each Mode - 8.10 Notes on Using 8/16-bit Capture Timer/Counter - 8.11 Program Example for 8/16-bit Capture Timer/Counter # 8.1 Overview of 8/16-bit Capture Timer/Counter The 8/16-bit capture timer/counter consists of two 8-bit counters (timer 0 and timer 1). These counters can be used separately (8-bit mode) or in combination (16-bit mode). Timer 0 provides seven internal count clocks. This timer can select the interval timer function or counter function. The interval timer function increments the counter value in synchronization with one of the seven internal clocks. The counter function increments the counter value according to the clock to be input to an external pin. Timer 0 can output square waves of any frequency according to outputs from the interval timer and counter. Timer 1 provides seven internal count clocks. This timer can output square waves of any frequency but can use only the interval timer function that increments the timer value in synchronization with one of the seven internal counter clocks. For the 16-bit mode, timer 0 and timer 1 are connected in series to serve as a 16-bit timer. #### ■ Interval Timer Function The interval timer function generates interrupt requests repeatedly at any time interval. This function can also invert the output level of P34/TO/INT10 pin per time interval and output square waves of any frequency. - In the 8-bit mode, the interval timer function operates as two independent timers: timer 0 (8-bit capture timer/counter) and timer 1 (8-bit timer). Interval timer operation from each count clock cycle to a 2<sup>8</sup> times cycle is possible. - The interval timer function can select and output square waves to the TO pin according to the timer 0 or 1 output. - In the 16-bit mode, the interval timer function operates as a 16-bit capture timer/counter in which timer 0 is concatenated as the lower counter and timer 1 is concatenated as the upper counter. Interval timer operation from the count clock cycle to the 2<sup>16</sup> times cycle is possible. - The count clock can be selected from the seven internal clock cycles (if timer 0 selects an external clock, the interval timer function operates as the capture/counter function). - The timer 0 output cycle can be used as the clock for starting A/D converters continuously or as the 8-bit PWM timer count clock. Table 8.1-1 to Table 8.1-3 show the interval time and square wave output range in each operation mode. Table 8.1-1 Timer 0 Interval Time and Square Wave Output Range in 8-bit Mode | Count clock | cycle | Interval time | Square wave output range (Hz) | | |----------------------|----------------------|-----------------------------------------------------------------------|----------------------------------------------|--| | | 2t <sub>INST</sub> | 2t <sub>INST</sub> to 2 <sup>9</sup> t <sub>INST</sub> | $1/(2^2 t_{INST})$ to $1/(2^{10} t_{INST})$ | | | | 4t <sub>INST</sub> | $2^2 t_{INST}$ to $2^{10} t_{INST}$ | $1/(2^3 t_{INST})$ to $1/(2^{11} t_{INST})$ | | | | 16t <sub>INST</sub> | 2 <sup>4</sup> t <sub>INST</sub> to 2 <sup>12</sup> t <sub>INST</sub> | $1/(2^5 t_{INST})$ to $1/(2^{13} t_{INST})$ | | | Internal count clock | 64t <sub>INST</sub> | $2^6 t_{INST}$ to $2^{14} t_{INST}$ | $1/(2^{7}t_{INST})$ to $1/(2^{15}t_{INST})$ | | | | 128t <sub>INST</sub> | 2 <sup>7</sup> t <sub>INST</sub> to 2 <sup>15</sup> t <sub>INST</sub> | $1/(2^8 t_{INST})$ to $1/(2^{16} t_{INST})$ | | | | 256t <sub>INST</sub> | $2^8 t_{INST}$ to $2^{16} t_{INST}$ | $1/(2^9 t_{INST})$ to $1/(2^{17} t_{INST})$ | | | | 512t <sub>INST</sub> | 29t <sub>INST</sub> to 2 <sup>17</sup> t <sub>INST</sub> | $1/(2^{10}t_{INST})$ to $1/(2^{18}t_{INST})$ | | | External clock | 1t <sub>ext</sub> | 1t <sub>ext</sub> to 2 <sup>8</sup> t <sub>ext</sub> | $1/(2t_{\rm ext})$ to $1/(2^9t_{\rm ext})$ | | Table 8.1-2 Timer 1 Interval Time and Square Wave Output Range in 8-bit Mode | Count clock cycle | | Interval time | Square wave output range (Hz) | | |----------------------|----------------------|-----------------------------------------------------------------------|----------------------------------------------|--| | | 2t <sub>INST</sub> | 2t <sub>INST</sub> to 2 <sup>9</sup> t <sub>INST</sub> | $1/(2^2 t_{INST})$ to $1/(2^{10} t_{INST})$ | | | | 4t <sub>INST</sub> | $2^2 t_{INST}$ to $2^{10} t_{INST}$ | $1/(2^3 t_{INST})$ to $1/(2^{11} t_{INST})$ | | | | 16t <sub>INST</sub> | 2 <sup>4</sup> t <sub>INST</sub> to 2 <sup>12</sup> t <sub>INST</sub> | $1/(2^5 t_{INST})$ to $1/(2^{13} t_{INST})$ | | | Internal count clock | 64t <sub>INST</sub> | 2 <sup>6</sup> t <sub>INST</sub> to 2 <sup>14</sup> t <sub>INST</sub> | $1/(2^{7}t_{INST})$ to $1/(2^{15}t_{INST})$ | | | | 128t <sub>INST</sub> | 2 <sup>7</sup> t <sub>INST</sub> to 2 <sup>15</sup> t <sub>INST</sub> | $1/(2^8 t_{INST})$ to $1/(2^{16} t_{INST})$ | | | | 256t <sub>INST</sub> | 2 <sup>8</sup> t <sub>INST</sub> to 2 <sup>16</sup> t <sub>INST</sub> | $1/(2^9 t_{INST})$ to $1/(2^{17} t_{INST})$ | | | | 512t <sub>INST</sub> | 29t <sub>INST</sub> to 2 <sup>17</sup> t <sub>INST</sub> | $1/(2^{10}t_{INST})$ to $1/(2^{18}t_{INST})$ | | Table 8.1-3 Interval Time and Square Wave Output Range in 16-bit Mode | Count clock cycle | | Interval time | Square wave output range (Hz) | | |----------------------|----------------------|-----------------------------------------------------------------------|-----------------------------------------------|--| | | 2t <sub>INST</sub> | 2t <sub>INST</sub> to 2 <sup>17</sup> t <sub>INST</sub> | $1/(2^2 t_{INST})$ to $1/(2^{18} t_{INST})$ | | | | 4t <sub>INST</sub> | $2^2 t_{INST}$ to $2^{18} t_{INST}$ | $1/(2^3 t_{INST})$ to $1/(2^{19} t_{INST})$ | | | | 16t <sub>INST</sub> | 2 <sup>4</sup> t <sub>INST</sub> to 2 <sup>20</sup> t <sub>INST</sub> | $1/(2^5 t_{INST})$ to $1/(2^{21} t_{INST})$ | | | Internal count clock | 64t <sub>INST</sub> | $2^6 t_{INST}$ to $2^{22} t_{INST}$ | $1/(2^{7}t_{INST})$ to $1/(2^{23}t_{INST})$ | | | | 128t <sub>INST</sub> | $2^{7}$ t <sub>INST</sub> to $2^{23}$ t <sub>INST</sub> | $1/(2^8 t_{INST})$ to $1/(2^{24} t_{INST})$ | | | | 256t <sub>INST</sub> | 28t <sub>INST</sub> to 2 <sup>24</sup> t <sub>INST</sub> | $1/(2^9 t_{INST})$ to $1/(2^{25} t_{INST})$ | | | | 512t <sub>INST</sub> | 29t <sub>INST</sub> to 2 <sup>25</sup> t <sub>INST</sub> | $1/(2^{10}t_{INST})$ to $1/(2^{26}t_{INST})$ | | | External clock | 1t <sub>EXT</sub> | 1t <sub>EXT</sub> to 2 <sup>16</sup> t <sub>EXT</sub> | $1/(2t_{\rm EXT})$ to $1/(2^{17}t_{\rm EXT})$ | | $t_{\mbox{\footnotesize{INST}}}\!:\!$ Instruction cycle (this cycle is affected by the clock mode, etc.) $t_{\mbox{\footnotesize{EXT}}}$ : External clock cycle (1 $t_{\mbox{\footnotesize{EXT}}}$ greater than or equal to $4t_{\mbox{\footnotesize{INST}}})$ #### Note: Example of calculating interval time and square wave frequency If the oscillation ( $F_{CH}$ ) is set to 12.5 MHz, the timer 0 data register (TDR0) value is set to $DD_H(221)$ , and the count clock cycle is set to $2t_{INST}$ 8-bit mode operation, the interval time of timer 0 and the square wave frequency output from the TO pin when the interval timer function is operated continuously without modifying the TDR0 register value are calculated from the following expressions: However, the values calculated from these expressions are valid when the highest speed clock of the normal mode (CS1, CS0 = $11_B$ , 1 instruction cycle = $4/F_{CH}$ ) is selected according to the system clock control register (SYCC). Interval time = $$(2 4/F_{CH})$$ (TDR0#1 register value + 1) = $(8/12.5 MHz)$ (221 + 1) $\Rightarrow 142.1 s$ Output frequency = $F_{CH}/(2 8 (TDR0#1 register value + 1))$ = $12.5 MHz/(16 (221 + 1))$ $\Rightarrow 3.53 kHz$ ### **■** Counter Function The counter function counts the falling edges of the external clocks input to the P33/EC external pin. The 8/16-bit capture timer/counter can operate independently because the EC pin acts as an external clock input pin. Only timer 0 can select the external clock. The counter function operates using timer 0 with the 8-bit mode or with the 16-bit mode. - The counter function counts the number of edges of the external clocks selected by the count clock selection bit (CINV) of the timer 0 control register (TCR0). When the number of edges equals the setting value, the counter function generates an interrupt request and inverts the output level of the square wave output pin. - In timer 0 for the 8-bit mode, a count operation up to $2^8$ is possible. - In the 16-bit mode, a count operation up to $2^{16}$ is possible. - Inputting an external clock whose cycle is constant enables the counter to be used as a device whose function is similar to an interval timer. # 8.2 Configuration of 8/16-bit Capture Timer/Counter The 8/16-bit capture timer/counter consists of the following seven blocks: - Count clock selectors 0/1 - Counter circuits 0/1 - Square wave output control circuit - Timer 0/1 data registers (TDR0, TDR1) - Timer 0/1 control registers (TCR0, TCR1) - Capture data registers (TCPL, TCPH) - Timer output control register (TCR2) ## ■ Block Diagram of 8/16-bit Capture Timer/Counter Figure 8.2-1 Block Diagram of 8/16-bit Capture Timer/Counter #### Count clock selectors 0/1 Circuits that select input clocks. In timer 0 for the 8-bit mode or in the 16-bit mode, count clock selector 0/1 can select seven internal clocks and one external clock. In timer 1 for the 8-bit mode, the selector can select only seven internal clocks. ### Counter circuits 0/1 Counter circuit 0 and counter circuit 1 each consist of an 8-bit counter, a comparator, a comparator data latch, and data registers (TDR0, TDR1). The 8-bit counter is incremented according to the selected count clock and clock edge (rising/falling). The comparator compares the counter value with the comparator data latch value. When these values match, the counter is cleared and the data register value is set in (loaded to) the comparator data latch. In the 8-bit mode, counter circuits 0 and 1 operate independently as timer 0 and timer 1, respectively. In the 16-bit mode, counter circuits 0 and 1 operate as the 16-bit counter in which counter circuit 0 is concatenated as lower 8 bits and counter circuit 1 is concatenated as higher 8 bits. ### Square wave output control circuit When the comparator detects that the counter value matches the comparator data latch value in the 8- or 16-bit mode, an interrupt request is generated. In this case, if square wave output is allowed, the corresponding output control circuit inverts the output of the square wave output pin. ### ■ Timer 0/1 data registers (TDR0, TDR1) TDR0 and TDR1 are used to set the data to be compared with each 8-bit counter value at write. ### Timer 0/1 control registers (TCR0, TCR1) TCR0 and TCR1 are used to select functions, allow and prohibit operations, control interrupts, and check interrupt states. ## 8/16-bit capture timer/counter interrupt IRQ3: If the interrupt request output is allowed when the counter value equals the value set in the data register in the interval timer or counter function, an IRQ3 interrupt request is generated. (In timer 0 for the 8-bit mode or in the 16-bit mode, the interrupt request output is allowed when TCR0: T0IEN=1. In timer 1 for the 8-bit mode, the interrupt request output is allowed when TCR1: T1IEN=1.) ### 8/16-bit capture counter interrupt IRQ4: If the interrupt request output is allowed each time a capture input edge is detected, an IRQ4 interrupt request is generated. (In timer 0 for the 8-bit mode or in the 16-bit mode, the interrupt request output is allowed when TCCR: TCEN=1.) ### Capture data registers (TCPL, TCPH) TCPL and TCPH store the number of events detected in the capture mode. When capture data is read in the timer mode, the counter value is also read. ## Timer output control register (TCR2) TCR2 is used to allow and prohibit square wave output and select timer 0 output/timer 1 output. ## 8.3 Pins of 8/16-bit Capture Timer/Counter This section provides pins of 8/16-bit capture timer/counter and a block diagram for these pins. ## ■ Pins of 8/16-bit Capture Timer/Counter 8/16-bit capture timer/counter pins include P33/EC and P34/TO/INT10. ### • P33/EC pin The P33/EC pin shares functions of the general-purpose I/O port (P33) and the external clock for the timer or capture input pin (EC). ### EC: When external clock input is selected (TCR0: TCS02, TCS01, TCS00=111<sub>B</sub>) in timer 0 for the 8-bit mode or in the 16-bit mode, the clocks input to this pin are counted. In the capture function, this pin is also used as an input pin. When using this pin as the EC pin, set 0 in the port data 3-direction register (DDR3: bit3) and set the output transistor to OFF to enable the EC pin to be used as an input port. ## • P34/TO/INT10 pin The P34/TO/INT10 pin shares functions of the general-purpose I/O port (P34) and the square wave output pin for the timer (TO). It also shares a function of the input pin for external interrupt 1 (INT10). ### TO: In timer 0 or 1 (switching allowed) for the 8-bit mode or in the 16-bit mode, a square wave is output from this pin. If square wave output is enabled (TCR2: PEN = 1), the P34/TO/INT10 pin automatically functions as an output pin without reference to the port 3-direction register (DDR3: bit4); it functions as the TO pin. The TCR2: TSEL is used to select whether timer 0 output or timer 1 output is to be used. ## ■ Block Diagram for 8/16-bit Capture Timer/Counter Pins External interrupt allowed INT10 ← □P34/TO/INT10 □ P33/EC EC ← **PDR** Stop mode (SPL = 1) Resource input PDR read Pull-up resistor ገ Resource output Resource output enable available Internal data bus PDR read (At read-modify-write) P-ch Output 0 latch PDR write Pin P33/EC P34/TO/INT10 N-ch **DDR** DĎŔ write Stop mode (SPL = 1) 7/7 PUL read **PUL** PUL write Figure 8.3-1 Block Diagram for 8/16-bit Capture Timer/Counter Pins ### Note: When "pull-up resistor available" is selected in the pull-up setting register, the pin state in the stop mode (SPL=1) becomes high (pull-up state), not Hi-Z. During the reset, however, pull-up becomes ineffective and the pin state becomes Hi-Z. # 8.4 Registers of 8/16-bit Capture Timer/Counter This section shows registers of 8/16-bit capture timer/counter. ## ■ Registers of 8/16-bit Capture Timer/Counter Figure 8.4-1 Registers of 8/16-bit Capture Timer/Counter | TCCR (captur | | - | | | | | | | Initial value | |-------------------|----------------------------------------------|------------|----------|-------|-------|-------|-------|-------|-----------------------| | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | | 0019 <sub>Н</sub> | CPIF | CFCLR | CPIEN | CCMSK | TCMSK | EDGS1 | EDGS0 | RESV | 00000000B | | | R | R/W | | TCR1 (timer 1 | control | register) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 001A <sub>H</sub> | TIF1 | TFCR1 | T1IEN | _ | TCS12 | TCS11 | TCS10 | TSTR1 | 000-0000 <sub>B</sub> | | | R | R/W | R/W | | R/W | R/W | R/W | R/W | | | TCR0 (timer 0 | ) control | register) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 001B <sub>H</sub> | TIF0 | TFCR0 | TOIEN | CINV | TCS02 | TCS01 | TCS00 | TSTR0 | 0000000B | | | R | R/W | | TDR1 (timer 1 | data red | aister) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 001Сн | | | | | | | | | XXXXXXX | | | R/W | | TDR0 (timer 0 | data reg | gister) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 001D <sub>H</sub> | | | | | | | | | XXXXXXXX | | | R/W | | TCPH (captur | e data re | gister H) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 001EH | | | | | | | | | XXXXXXX | | | R | R | R | R | R | R | R | R | | | TCPL (capture | e data re | gister L) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 001F <sub>H</sub> | | | | | | | | | XXXXXXX | | | R | R | R | R | R | R | R | R | | | TCR2 (timer c | utput co | ntrol regi | ster) | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0020н | | _ | | _ | | _ | PEN | TSEL | 00 <sub>B</sub> | | R : F<br>X : U | Readable<br>Read only<br>Indefined<br>Inused | | <b>:</b> | | | | R/W | R/W | | # 8.4.1 Capture Control Register (TCCR) The capture control register (TCCR) is used to select functions and detection edges, control interrupts, and check interrupt states in timer 0 for the 8-bit mode of the 8/16 bit capture timer/counter or in capture mode (16-bit mode). ## ■ Capture Control Register (TCCR) Figure 8.4-2 Capture Control Register (TCCR) Table 8.4-1 Explanation of Functions of Each Bit in Capture Control Register (TCCR) | | Bit name | Function | |---------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | CPIF:<br>Capture edge detection<br>flag bit | This bit is set to "1" when the edge specified by EDGS1 and EDGS0 is detected. An interrupt request is output when this bit and the capture interrupt request enable bit (CPIEN) are "1". | | bit6 | CFCLR:<br>Capture edge detection<br>flag clear bit | <ul> <li>This bit is used to clear the capture edge detection flag.</li> <li>When this bit is "1" at write, the capture edge detection flag is cleared. When "0", the capture edge detection flag is not affected (remains unchanged).</li> </ul> | | bit5 | CPIEN:<br>Capture interrupt request<br>enable bit | <ul> <li>This bit is used to allow and prohibit interrupt request output to the CPU.</li> <li>An interrupt request is output when this bit and the capture edge detection flag bit (CPIF) are "1".</li> </ul> | | bit4 | CCMSK: Counter clear mask bit (at capture operation) | <ul> <li>The counter state when a capture match is detected is set.</li> <li>When this bit is "0", the counter is cleared. When this bit is "1", the counter is not cleared.</li> </ul> | | bit3 | TCMSK:<br>Compare match counter<br>clear mask bit | <ul> <li>The counter state when a compare edge is detected is set.</li> <li>When this bit is "0", the counter is cleared. When this bit is "1", the counter is not cleared.</li> </ul> | | bit2,<br>bit1 | EDGS1 and EDGS0:<br>Capture mode enable/<br>edge detection selection<br>bits | <ul> <li>These bits are used to allow and prohibit the capture function and select capture edges.</li> <li>When using the 8/16-bit capture timer/counter in the capture mode, set these bits to a value other than "00<sub>B</sub>".</li> <li>When the edge set by these bits is input, the capture edge detection flag bit (CPIF) is set to "1".</li> </ul> | | bit0 | RESV: Reserved bit | Even if this bit is set to "0" or "1", the operation is not affected. The value previously written becomes the read value. | ## 8.4.2 Timer 0 Control Register (TCR0) The timer 0 control register (TCR0) is used to select functions, allow and prohibit operation, control interrupts, and check interrupt states in timer 0 for the 8-bit mode of the 8/16-bit capture timer/counter or in the 16-bit mode. Even if only timer 0 is used in the 8-bit mode, the timer 1 control register (TCR1) must be initialized. ## ■ Timer 0 Control Register (TCR0) bit7 bit6 bit5 hit4 hit3 hit2 hit1 bit0 Address Initial value TFCR0 TIF0 **TOIEN** CINV TCS02 TCS01 TCS00 001B<sub>H</sub> TSTR0 00000000<sub>B</sub> R/W R/W R/W R/W R/W TSTR0 Timer start bit The counter operation is stopped. The counter is cleared and increment starts. TCS02 TCS01 TCS00 Clock source selection bits (oscillation: 12.5 MHz) 0 $2t_{INST}$ [0.64 $\mu$ s] 0 4t<sub>INST</sub> [1.28 μs] 0 1 0 16t<sub>INST</sub> [5.12 μs] 64t<sub>INST</sub> [20.48 μs] 0 1 0 0 128t<sub>INST</sub> [40.96 μs] 1 256t<sub>INST</sub> [81.92 μs] 512t<sub>INST</sub> [163.84 μs] 1 0 External clock t<sub>INST</sub>: Instruction cycle (Affected by the clock mode and others.) Count clock selection bit The counter is incremented at the falling edge of a selected 0 clock source. The counter is incremented at the rising edge of a selected 1 clock source. T0IEN Interrupt request enable bit 0 Interrupt request output is prohibited. Interrupt request output is allowed. TFCR0 Compare match detection flag clear bit Not affected (at read, always "0") 0 The compare match detection flag is cleared. 1 TIF0 Compare match detection flag bit 0 No compare match has occurred. 1 A compare match occurred R/W: Readable/Writable : Read only : Initial value Figure 8.4-3 Timer 0 Control Register (TCR0) Table 8.4-2 Explanation of Functions of Each Bit in Timer 0 Control Register (TCR0) | | Bit name | Function | |--------------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | TIF0:<br>Compare match<br>detection flag bit | <ul> <li>8-bit mode When the counter value of timer 0 matches the value (comparator data latch) set in the timer 0 data register (TDR0), this bit is set to "1".</li> <li>16-bit mode When the counter value of timer 0 matches the value set in TDR0 and the counter value of timer 1 matches the value set in TDR1, this bit is set to "1".</li> <li>An interrupt request is output when this bit and the interrupt request enable bit (T0IEN) are "1".</li> </ul> | | bit6 | TFCR0:<br>Compare match<br>detection flag clear bit | • This bit is used to clear the compare match detection flag bit (TIF0). When this bit is set to "1", the compare match detection flag is cleared. The flag is not affected even if this bit is set to "0". | | bit5 | T0IEN:<br>Interrupt request enable<br>bit | <ul> <li>This bit is used to allow and prohibit interrupt request output to the CPU.</li> <li>An interrupt request is output when this bit and the interrupt request enable bit (T0IEN) are "1".</li> </ul> | | bit4 | CINV:<br>Count clock selection bit | • This bit is used to select whether to increment the counter at the rising or falling edge of a clock. When this bit is "0", the counter is incremented at the falling edge of the clock. When "1", the counter is incremented at the rising edge. | | bit3<br>to<br>bit1 | TCS02, TCS01, TCS00:<br>Clock source selection<br>bits | <ul> <li>These bits are used to select the count clocks to be supplied to the counter.</li> <li>Select one clock from the seven internal clocks and one external clock.</li> <li>When these bits are 111<sub>B</sub>, the external clock is input. In this case, timer 0 can operate as the counter function.</li> <li>Note: When external clock input is selected (TCS02, TCS01, TCS00 = 111<sub>B</sub>), the P33/EC pin must be set in the input port.</li> </ul> | | bit0 | TSTR0:<br>Timer start bit | <ul> <li>This bit is used to start and stop the counter.</li> <li>When this bit is set to "1", the counter is cleared and incremented according to the selected count clock. When this bit is set to "0", the counter stops its operation.</li> <li>When the timer is started (TSTR0 = 0 →1) in the 16-bit mode, the counters of both timer 0 and timer 1 are cleared.</li> </ul> | ## Note: When using only timer 0 of the 8/16-bit capture timer/counter in the 8-bit mode, set a value other than $111_B$ in the count clock selection bits (TCS12, TCS11, TCS10) of the timer 1 control register (TCR1). Using timer 0 with setting value TCS12, TCS11, TCS10 = $111_B$ results in a malfunction. # 8.4.3 Timer 1 Control Register (TCR1) The timer 1 control register (TCR1) is used to select functions, allow and prohibit operation, control interrupts, and check interrupt states in timer 1 for the 8-bit mode of the 8/16-bit capture timer/counter. When used in the 16-bit mode, TCR1 is controlled by the timer 0 control register (TCR0), but TCR1 setting is required. ## ■ Timer 1 Control Register (TCR1) Figure 8.4-4 Timer 1 Control Register (TCR1) Table 8.4-3 Explanation of Functions of Each Bit in Timer 1 Control Register (TCR1) | | Bit name | Function | |--------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | TIF1:<br>Compare match<br>detection flag bit | <ul> <li>This bit is set to "1" when the counter value of timer 1 matches the value (comparator data latch) set in the timer 1 data register (TDR1).</li> <li>An interrupt request is output when this bit and the interrupt request enable bit (T1IEN) are "1".</li> <li>Note: <ul> <li>In the 16-bit mode, the TIF0 bit of TCR0 is valid. The TIF1 bit is unrelated to operation.</li> </ul> </li> </ul> | | bit6 | TFCR1:<br>Compare match<br>detection flag clear bit | • This bit is used to clear the compare match detection flag bit (TIF1). When this bit is set to "1", the compare match detection flag is cleared. The flag is not affected even if this bit is set to "0". | | bit5 | T1IEN:<br>Interrupt request enable<br>bit | <ul> <li>This bit is used to allow and prohibit interrupt request output to the CPU.</li> <li>An interrupt request is output when this bit and the interrupt request enable bit (T0IEN) are "1".</li> </ul> | | bit4 | Not used | <ul><li>This bit is undefined at read.</li><li>At write, this bit does not affect operation.</li></ul> | | bit3<br>to<br>bit1 | TCS12, TCS11, TCS10:<br>Clock source selection<br>bits | <ul> <li>These bits are used to select the count clocks to be supplied to the counter.</li> <li>Of seven internal clocks, select one.</li> <li>When 111<sub>B</sub> is written to these bits, timer 1 operates as the 16-bit mode.</li> <li>Note: In the 16-bit mode, the TCS02, TCS01, and TCS00 bits are valid. The TCS12, TCS11, and TCS10 bits are used to select the 16-bit mode only.</li> </ul> | | bit0 | TSTR1:<br>Timer start bit | <ul> <li>This bit is used to start and stop the counter.</li> <li>When this bit is set to "1", the counter is cleared and incremented according to the selected count clock. When this bit is set to "0", the counter stops its operation.</li> <li>In the 16-bit mode, only the TSTR0 bit can be used to start the timer. The TSTR1 bit is unrelated to operation.</li> </ul> | ## **Note:** When using timer 1 in the 16-bit mode, write $111_{\rm B}$ to the TCS12, TCS11, and TCS10 bits and then control timer 1 with TCR0. # 8.4.4 Timer Output Control Register (TCR2) The timer output control register (TCR2) is used to allow and prohibit the square wave output of the 8/16-bit capture timer/counter and select timer 0 output and timer 1 output. ## **■** Timer Output Control Register (TCR2) Figure 8.4-5 Timer Output Control Register (TCR2) Table 8.4-4 Explanation of Functions of Each Bit in Timer Output Control Register (TCR2) | | Bit name | Function | | | |--------------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | bit7<br>to<br>bit2 | Unused bits | <ul> <li>At read, the values of these bits are undefined.</li> <li>At write, these bits do not affect operation.</li> </ul> | | | | bit1 | PEN:<br>Port output enable bit | • When this bit is "0", the P34/TO/INT10 pin acts as the general-purpose port (P34). When "1", it acts as the square wave output pin (TO). | | | | bit0 | TSEL:<br>Timer output selection bit | When this bit is "0", timer 0 output in the 8-bit mode or output in the 16-bit mode is selected. In this case, data is output from the TO pin. When "1", timer 1 output in the 8-bit mode is selected. In this case, data is also output from the TO pin. | | | ## 8.4.5 Timer 0 Data Register (TDR0) The timer 0 data register (TDR0) is used to set the timer 0 value in the 8-bit mode of the 8/16-bit capture timer/counter or the interval timer value (interval timer function) or counter value (counter function) of the lower 8 bits in 16-bit mode. ## ■ Timer 0 Data Register (TDR0) The values set in this register are compared with those set in the counter. Figure 8.4-6 shows the bit structure of timer 0 data register (TDR0). Figure 8.4-6 Timer 0 Data Register (TDR0) ## • 8-bit mode (timer 0) The values set in this register are compared with those set in the counter. When the interval timer function is used, an interval timer value is set. When the counter function is used, the count value to be detected is set. When the count operation is allowed (TCR0: TSTR0 = $0 \rightarrow 1$ ), the value in TDR0 is set in (loaded to) the comparator data latch and the counter is incremented. When the values in the comparator data latch match those in the counter as a result of the increment, the values in the TDR0 are reset in the comparator data latch, the counter is cleared, and the count operation is continued. The comparator data latch is reset when a match is detected, thus, the values written to the TDR0 when the counter is in operation become valid from the next cycle (after match detection). ### Note: The values set in TDR0 when the interval timer is in operation can be calculated from the expression shown below. However, the instruction cycle is affected by the clock mode and gear function. Values set in TDR0 = interval time/(count clock cycle × instruction cycle) - 1 ## • 16-bit mode The values in TDR0 are compared with the counter values in the lower 8 bits of the 16-bit timer. When the interval timer function is used, the lower 8 bits of the interval time are set. When the counter function is used, the lower 8 bits of the count value to be detected are set. The values in TDR0 are loaded to the lower 8 bits of the comparator data latch when matching the counter values of the 16-bit timer or when the count operation is started. The values written to TDR0 when the 16-bit counter is in operation become valid after match detection. For the values set in TDR1 when the interval timer function is used, see Section "8.4.6 Timer 1 Data Register (TDR1) ". ## 8.4.6 Timer 1 Data Register (TDR1) The timer 1 data register (TDR1) is used to set the timer 1 value in the 8-bit mode of the 8/16-bit capture timer/counter or the interval timer value (interval timer function) or counter value (counter function) of the higher 8 bits in the 16-bit mode. ## ■ Timer 1 Data Register (TDR1) The values set in this register are compared with those set in the counter. Figure 8.4-7 shows the bit structure of timer 1 data register (TDR1). Figure 8.4-7 Timer 1 Data Register (TDR1) ### • 8-bit mode (timer 1) The values set in this register are compared with those set in the counter. When the interval timer function is used, an interval timer value is set. When the counter function is used, the count value to be detected is set. The values in TDR1 are reset in (loaded to) the comparator data latch when they match the values in the counter or when the count operation is started. The values written to TDR1 when the counter is operating become valid from the next cycle (after match detection). ## Note: The values set in TDR1 when the interval timer is operating can be calculated from the expression shown below. However, the instruction cycle is affected by the clock mode and gear function. Values set in TDR1 = interval time/(count clock cycle $\times$ instruction cycle) - 1 ### • 16-bit mode The values in TDR1 are compared with the counter values in the higher 8 bits of the 16-bit timer. When the interval timer function is used, the higher 8 bits of the interval time are set. When the counter function is used, the higher 8 bits of the count value to be detected are set. The values in TDR1 are loaded to the higher 8 bits of the comparator data latch when matching the counter values of the 16-bit timer or when the count operation is started. The values written to TDR1 when the 16-bit counter is operating become valid after match detection. In the 16-bit mode, the count operation is controlled by the timer 0 control register (TCR0). ### Note: The values set in TDR0 and TDR1 when the interval function is used can be calculated from the expression shown below. However, the instruction cycle is affected by the clock mode and gear function. 16-bit data value = interval time/(count clock cycle × instruction cycle) - 1 The higher 8 bits of the 16-bit data value are set in TDR1 and the lower 8 bits are set in TDR0. ## 8.4.7 Capture Data Registers H and L (TCPH and TCPL) The capture data register H (TCPH) stores the number of events of the higher 8 bits in the 16-bit capture mode of the 8/16-bit capture timer/counter. The capture data register L (TCPL) stores the number of events in the 8-bit capture mode of the 8/16-bit capture timer/counter or the number of events of the lower 8 bits in the 16-bit capture mode. In the read operation in the timer/counter mode, counter values are read. ## ■ Capture Data Registers H and L (TCPH and TCPL) The number of events detected in the capture mode is stored in TCPH and TCPL. Data cannot be written to these registers because the registers are read-only. Figure 8.4-8 shows the bit structures of capture data registers H and L. Figure 8.4-8 Bit Structures of Capture Data Registers H and L (TCPH and TCPL) ## 8.5 8/16-bit Capture Timer/Counter of Interrupts The 8/16-bit capture timer/counter generates an interrupt if the values set in a data register match those set in the counter when the interval timer or counter is operating. The interrupt level is IRQ3 when generated by the 8/16-bit capture timer/counter. When the capture is in operation and a capture edge is detected, IRQ4 is generated. ## ■ 8/16-bit Capture Timer/Counter of Interrupts Table 8.5-1 shows the interrupt request flag bit, interrupt flag clear bit, interrupt request enable bit, and the cause of the 8/16-bit capture timer/counter interruption. Table 8.5-1 Interrupt Control Bits and the Cause of the 8/16-bit Capture Timer/Counter Interrupt | | 8-bit | mode | 16-bit mode | Capture mode | | |------------------------------|------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------|------------------------------|--| | | Timer 0 | Timer 1 | Timer 0 + timer 1 | Timer 0 or timer 0 + timer 1 | | | Interrupt request flag bit | TCR0 : TIF0 | TCR1 : TIF1 | TCR0 : TIF0 | TCCR : CPIF | | | Interrupt flag clear bit | TCR0: TFCR0 | TCR1: TFCR1 | TCR0: TFCR0 | TCCR : CFCLR | | | Interrupt request enable bit | TCR0 : T0IEN | TCR1: T1IEN | TCR0 : T0IEN | TCCR : CPIEN | | | Interrupt cause | The values in TDR0 match those in the 8-bit counter. | The values in TDR1 match those in the 8-bit counter. | The values in TDR0 and TDR1 match those in the 16-bit counter. | A capture edge is detected. | | In the 8-bit mode, timer 0 and timer 1 independently generats the interrupt request for 8/16-bit capture timer/counter. In the 16-bit mode, timer 0 generates the interrupt request. All basic operations are the same. Timer 0 interrupt operation in the 8-bit mode is explained here. ### Timer 0 interrupt operation in the 8-bit mode The counter value is incremented according to the selected count clock, starting at $00_H$ . When the counter value matches the value set in the comparator data latch (timer 0 data register (TDR0)) corresponding to the timer 0 data register (TDR0), the compare match detection flag bit (TCR0: TIF0) is set to "1". In this case, when the interrupt request flag bit is allowed (when TCR0: T0IEN = 1), timer 0 generates an interrupt request (IRQ3) to the CPU. Set the TFCR0 bit to "1" and clear the interrupt request with the interrupt processing routine. When the counter value matches the value set in the comparator data latch, the TIF0 bit is set to "1" regardless of the TFCR0 bit value. In the 8-bit mode, timer 0 and timer 1 operate independently, and because they generate the same interrupt request (IRQ3), determination of the interrupt request flag by software may be required. ### **Notes:** - When the counter value matches the TDR0 value and at the same time the counter stops (TCR0: TSTR0 = 0), the TIF0 bit is not set. If the T0IEN bit is set to "1" (enable) when the TIF0 bit is "1", an interrupt request is generated immediately. - If the compare register value is $0000_H$ or $00_H$ , the 8/16-bit capture timer/counter cannot generate an interrupt. Therefore, when using interrupts, set a value greater than or equal to $0001_H$ or $01_H$ . The 8/16-bit capture timer/counter also cannot generate an interrupt if the counter function detects the $0000_H$ or $00_H$ width. ## ■ Register and Vector Table Related to 8/16-bit Capture Timer/Counter of Interrupts Table 8.5-2 Register and Vector Table Related to 8/16-bit Capture Timer/counter of Interrupts | | Interrupt | Interrupt | Vector table address | | | | |------------------------|-----------|---------------------------|----------------------|------------|-------------------|-------------------| | | name | Register | Setting bit | | Higher | Lower | | Timer/counter function | IRQ3 | ILR1 (007B <sub>H</sub> ) | L31 (bit7) | L30 (bit6) | FFF4 <sub>H</sub> | FFF5 <sub>H</sub> | | Capture function | IRQ4 | ILR2 (007C <sub>H</sub> ) | L41 (bit1) | L40 (bit0) | FFF2 <sub>H</sub> | FFF3 <sub>H</sub> | For interrupt operation, see Section "3.4.2 Steps in the Interrupt Operation ". #### 8.6 **Explanation of Operations of Interval Timer Functions** This section describes the interval timer function operation of the 8/16-bit capture timer/ counter. ## ■ Interval Timer Function Operation #### 8-bit mode To operate timer 0 as the interval timer function in the 8-bit mode, the function must be set as shown in Figure 8.6-1. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 CFCLR **TCCR CPIF** Figure 8.6-1 Setting of Interval Timer Function (Timer 0) To operate timer 1 as the interval timer function in the 8-bit mode, the function must be set as shown in Figure 8.6-2. Figure 8.6-2 Setting of Interval Timer Function (Timer 1) When the counter is activated in the 8-bit mode, increment begins at the rising or falling edge of the selected clock, starting at $00_H$ . When the counter value matches the value set in the data register (comparator data latch), the interrupt request bit (TCR0: TIF0 or TCR1: TIF1) of the timer 0 control register is set to "1" and the count operation is started at $00_H$ . If the counter value matches the value set in the data register when timer 0 is being used, the output of the square wave output control circuit toggles. When square wave output is allowed (TCR2: PEN) and timer 0 is set to output selection (TCR2: TSEL = 0), a square wave is output from the timer output pin (TO). If the counter value matches the value set in the data register when timer 1 is being used, the output of the square wave output control circuit toggles. When square wave output is allowed (TCR2: PEN) and timer 1 is set to output selection (TCR2: TSEL = 1), a square wave is output from the timer output pin (TO). Figure 8.6-3 shows interval timer function operation in the 8-bit mode. Figure 8.6-3 Interval Timer Function Operation in 8-bit Mode (Timer 0) ### • 16-bit mode To operate timer 0 as the interval timer function in the 16-bit mode, the function must be set as shown in Figure 8.6-4. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 **TCCR CPIF** CFCLR CPIEN CCMSK TCMSK EDGS1 EDGS0 RESV $\times$ $\times$ $\times$ Setting of 00 <sup>-1</sup> TCR1 TIF1 TFCR1 T1IEN TCS12 TCS11 TCS10 TSTR1 1 1 1 X X $\times$ $\times$ TFCR0 **TOIEN** TCS02 TCS01 TCS00 TCR0 TIF0 **CINV** TSTR0 Setting of a value 0 0 0 0 0 other than 111 TCR2 PEN **TSEL** (0) 0 Setting of higher 8 bits of interval time TDR1 Setting of lower 8 bits of interval time TDR0 0 : Used bit : Unused bit $\times$ : Set "0" 0 : Set "1" 1 Figure 8.6-4 Setting of Interval Timer Function in 16-bit Mode In the 16-bit mode, timers are controlled by the timer 0 control register (TCR0), but the timer 1 control register (TCR1) must be initialized. The values to be set in the data register are the higher 8 bits of TDR1 and the lower 8 bits of TDR0 (16 bits in total). The values are compared with the 16-bit counter value. The 16 bits of the counter are cleared at the same time. Other operations in the 16-bit mode are the same as timer 0 operation in the 8-bit mode. # 8.7 Operation of Counter Functions This section describes the operation of the 8/16-bit capture timer/counter function. ## **■** Counter Function Operation ### 8-bit mode To operate timer 0 as the counter function in the 8-bit mode, the function must be set as shown in Figure 8.7-1. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 DDR3 $\times$ X X $\times$ 0 × $\times$ $\times$ CFCLR CPIEN CCMSK TCMSK EDGS1 EDGS0 RESV **CPIF TCCR** □ Setting of 00 □ $\times$ $\times$ $\times$ $\times$ TFCR1 T1IEN TIF1 TCR1 TCS12 TCS11 TCS10 TSTR1 Setting of a value other than 111 $\times$ $\times$ $\times$ TIF0 TFCR0 **TOIEN** CINV TCS02 TCS01 TCS00 TSTR0 TCR0 0 $\bigcirc$ 0 0 1 1 1 0 TCR2 PEN TSEL X $\times$ **TCDL** Number of detected events Setting of the counter value to be compared TDR0 0 : Used bit : Unused bit 0 : Set "0" : Set "1" Figure 8.7-1 Setting of Counter Function in 8-bit Mode Counter function operation in the 8-bit mode is the same as interval timer function (timer 0 in 8-bit mode) operation except that the external clock is used instead of the internal clock. The number of events can be known by reading the capture data register (TCPL). A specific number of events can be known by the event count detection function. ### Detection of the number of events In the external clock mode, counter clear can be prohibited by the compare match counter clear mask bit (TCMSK) of the capture control register (TCCR) when a match is detected. Setting the compare match counter clear mask bit to "1" enables the event count detection function to be used. In this case, a compare match does not cause data to be re-loaded to the compare latch. To update the compare latch value, stop and restart the timer. Figure 8.7-2 shows counter function operation in the external clock mode in which TCMSK is used. Figure 8.7-2 Counter Function Operation in External Clock Mode ### • 16-bit mode To operate timer 0 as the counter function in the 16 bit mode, the function must be set as shown in Figure 8.7-3. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 DDR3 $\times$ $\times$ $\times$ $\times$ 0 $\times$ $\times$ $\times$ CFCLR CPIEN CCMSK TCMSK | EDGS1 | EDGS0 | **CPIF TCCR** RESV X X $\times$ Setting of 00 <sup>→</sup> T1IEN TFCR1 TIF1 TCS12 TCS11 TCS10 TCR1 TSTR1 $\times$ $\times$ $\times$ 1 1 1 $\times$ TCR0 TIF0 TFCR0 **TOIEN** CINV TCS02 TCS01 TCS00 TSTR0 $\bigcirc$ 0 0 0 0 1 1 1 PEN TCR2 **TSEL** X Setting of the higher 8 bits of the counter value to be compared TDR1 Setting of the lower 8 bits of the counter value to be compared TDR0 **TCPH** Higher 8 bits of the number of detected events Lower 8 bits of the number of detected events **TCPL** 0 : Used bit : Unused bit 0 : Set "0" : Set "1" Figure 8.7-3 Setting of Counter Function in 16-bit Mode Counter function operation in the 16-bit mode is the same as interval timer function operation in the 16-bit mode, except that the external clock is used instead of the internal clock. Figure 8.7-4 shows counter function operation in 16-bit mode. Figure 8.7-4 Counter Function Operation in 16-bit Mode #### Note: Confirm the validity of the values set in the counter operating in 16-bit mode. ## 8.8 Functions of Operations of Capture Functions This section describes the capture function operation of the 8/16-bit capture timer/counter. ## **■** Capture Function Operation #### 8-bit mode To operate the capture function in the 8-bit mode, the function must be set as shown in Figure 8.8-1. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 DDR3 X X X X 0 X X TCMSK EDGS1 **TCCR CPIF** CFCLR CPIEN CCMSK EDGS0 RESV Setting of a value $^{\perp}$ other than 00 0 0 0 0 0 T1IEN TCR1 TIF1 TFCR1 TCS12 TCS11 TCS10 TSTR1 Setting of a value other $\ \ \, \bot$ than 111 $\times$ X TCR0 TIF<sub>0</sub> TFCR0 **TOIEN** CINV TCS02 TCS01 TCS00 TSTR0 0 0 0 0 0 Setting of a value other <sup>⊥</sup> than 111 TCR2 PEN **TSEL** $\times$ $\times$ **TCPL** Number of detected events 0 : Used bit $\times$ : Unused bit : Set "0" 0 Figure 8.8-1 Setting of Capture Function in 8-bit Mode The 8-bit capture mode is allowed by the capture mode enable/edge detection selection bits (EDGS1 and EDGS0) of the capture control register (TCCR). "1" is written to the timer start bit (TSTR0) after the clock source selection bits (TCS02, TCS01, and TCS00) of the timer 0 control register (TCR0) have been set. In the capture mode, the count value is captured to the capture data register (TCPL) each time a capture input edge is detected and the capture edge detection flag (CPIF) is set to "1". In this case, if the capture interrupt enable bit (CPIEN) is already set to "1", an interrupt request is output to the CPU. The capture mode is divided into free-run mode and clear mode. ### CHAPTER 8 8/16-BIT CAPTURE TIMER/COUNTER ### Free-run mode Setting the clear mask bits (CCMSK and TCMSK) of TCCR to $11_B$ enables the capture function to operate as the free-run timer. ### Clear mode Setting the clear mask bits (CCMSK and TCMSK) of TCCR to a value other than $11_B$ enables the capture function to operate as a clear mode. The clear mode enables the measurement of signal pulse widths and cycles. In this case, using the clear mode with the compare match detection function also enables the determination of signal availability. ### Note: The capture input pin also serves as the external clock input pin. The external clock mode cannot be used in the capture mode. Table 8.8-1 shows the relationship between the counter mode and the compare latch operation according to the clear mask bit value. Table 8.8-1 Relationship between Counter Mode and Compare Latch Operation | | | | Data load to compare latch and counter clear (provided/not provided) | | | | | | |-------|-------|---------------|----------------------------------------------------------------------|----------------|------------------|---------------|--|--| | CCMSK | TCMSK | Counter mode | At capture e | edge detection | At compare match | | | | | | | | Data load | Counter clear | Data load | Counter clear | | | | 0 | 0 | | Provided | Provided | Provided | Provided | | | | 0 | 1 | Clear mode | Provided | Provided | Not provided | Not provided | | | | 1 | 0 | | Not provided | Not provided | Provided | Provided | | | | 1 | 1 | Free-run mode | Not provided | Not provided | Not provided | Not provided | | | Figure 8.8-2 Capture Mode Operation ### • 16-bit mode To operate the capture function in the 16-bit mode, the function must be set as shown in Figure 8.8-3. bit5 bit4 bit3 bit2 bit1 bit0 bit7 bit6 DDR3 × X 0 $\times$ $\times$ $\times$ $\times$ X CPIF CFCLR CPIEN CCMSK TCMSK EDGS1 EDGS0 RESV **TCCR** └Setting of a value <sup>→</sup> other than 00 0 0 0 TIF1 TFCR1 T1IEN TCS12 TCS11 TCS10 TSTR1 TCR1 $\times$ $\times$ Setting of 111 $\times$ 0 TCR0 TIF0 TFCR0 T0IEN CINV TCS02 TCS01 TCS00 TSTR0 Setting of a value other than 111 0 0 0 0 PEN **TSEL** TCR2 X Higher 8 bits of the number of detected events **TCPH** Lower 8 bits of the number of detected events **TCPL** 0 : Used bit $\times$ : Unused bit 0 : Set "0" Figure 8.8-3 Setting of Capture Function in 16-bit Mode To set the 16-bit capture mode, set the TCS12, TCS11, and TCS10 bits of the timer 1 control register (TCR1) to $111_{\rm B}$ . In the 16-bit mode, timers are controlled by the timer 0 control register (TCR0). The higher 8 bits of the number of detected events are stored in the capture data register H (TCPH), and the lower 8 bits are stored in the capture data register L (TCPL). For operation in the 16-bit mode, see operation in the 8-bit mode. ## 8.9 8/16-bit Capture Timer/Counter Operation in Each Mode This section describes the operation of the 8/16-bit capture timer/counter when it switches to the sleep or stop mode or when a halfway stop request is issued during the operation of the interval timer or counter function. ## ■ Operation in Standby Mode and at Halfway Stop Figure 8.9-1 shows the counter value states if the 8/16-bit capture timer/counter switches to the sleep or stop mode or when a halfway stop request is issued when the interval timer or counter function is in operation (at timer 0 operation). When the counter switches to the stop mode, it retains the value and stops. If the stop mode is released by an external interrupt, the counter starts its operation at the retained value, and so the first interval time and external clock count are incorrect. When the stop mode is released, the 8/16-bit capture timer/counter must be initialized. When the counter is temporarily stopped (TSTR0 = 0), it retains its value and stops. If the subsequent operation is continued (TSTR0 = 1), the count value is cleared and the counter is restarted. Figure 8.9-1 Counter Operation in Standby Mode and at Halfway Stop ## 8.10 Notes on Using 8/16-bit Capture Timer/Counter This section provides notes on using the 8/16-bit capture timer/counter. ## ■ Notes on Using the 8/16-bit Capture Timer/Counter ### Error The start of the 8/16-bit capture timer/counter by a program is asynchronous with the start of the counter incremented by the selected count clock, and therefore, the error (a time difference) continues until the counter value matches the set data. Such a time difference may shorten the total count duration by a maximum of one count clock cycle. Figure 8.10-1 shows the error (a time difference) that prolongs the actual start of count operation. Counter value 0 1 2 3 4 Count clock Count 0 Error cycle Counter start Figure 8.10-1 Error Occurring until the Count Operation is Started ## Using only timer 0 in 8-bit mode When using only timer 0 of the 8/16-bit capture timer/counter in the 8-bit mode, set a value other than $111_B$ in the count clock selection bits (TCS12, TCS11, TCS10) of the timer 1 control register (TCR1). Using timer 0 without setting $111_B$ results in a malfunction. ## Note on setting by program When using the 8/16-bit capture timer/counter in the 16-bit mode, set the count clock selection bits (TCS12, TCS11, TCS10) of TCR1 to $111_B$ . Before using the counter values when the counter is in operation with 16-bit mode, be sure to read the counter values twice and confirm that the values are valid. Even if square wave output is initialized when the timer is in operation (TCR0: TSTR0 = 1), the output value is not modified. The output state is initialized when the timer operation stops. When the interrupt request flag bits (TCCR: CPIF, TCR0: TIF0, TCR1: TIF1) are "1" and the interrupt request enable bits are allowed (TCCR: CPIEN, TCR0: T0IEN, and TCR1: T1IEN = 1), return from an interrupt is impossible. In this case, clear the interrupt request flag bits (TCCR: CFCLR = 1, TCR0: TFCR0 = 1, and TCR1: TFCR1 = 1). When the counter operation stops according to the timer start bits (TCR0: TSTR0 = 0 and TCR1: TSTR1 = 0) and the interrupt source occurs at the same time, the interrupt request flag bits (TCR0: TIF0 and TCR1: TIF1) are not set. In the capture mode, no external clock can be selected; set the count clock bits (TCS12,TCS11, and TCR1: TCS10) to a value other than $111_B$ . ### Note on using interrupts If the compare register value is $0000_H$ or $00_H$ , the 8/16-bit capture timer/counter cannot generate interrupts. For this reason, when using interrupts, set a value greater than or equal to $0001_H$ or $01_H$ . The 8/16-bit capture timer/counter cannot generate interrupts if the capture counter function detects the $0000_H$ or $00_H$ width. # 8.11 Program Example for 8/16-bit Capture Timer/Counter This section provides program examples of the 8/16-bit capture timer/counter. ## ■ Program Example of Interval Timer Function ### Processing specifications - In the 8-bit mode, only timer 0 is used to generate a 20 ms interval timer interrupt. - When the interval time has elapsed, the square wave to be inverted is output to the TO pin. - At 12.5-MHz oscillation ( $F_{CH}$ ), the TDR0 value whose interval time becomes 20 ms at the maximum gear speed (1 instruction cycle = $4/F_{CH}$ ) is shown below. The count clock is $256t_{INST}$ of the internal count clock. TDR0 value = $20 \text{ ms/}(256 \times 4/12.5 \text{ MHz}) - 1 = 244 \text{ (F4}_{H})$ ## Coding example | TCCR | EQU | 0019H | ; | Address of capture control register | |-----------------|------|-----------------|---|------------------------------------------------------------------------| | TCR1 | EQU | 001AH | ; | Address of timer 1 control register | | TCR0 | EQU | 001BH | ; | Address of timer 0 control register | | TCR2 | EQU | 0020H | ; | Address of timer output control register | | TDR1 | EQU | 001CH | ; | Address of timer 1 data register | | TDR0 | EQU | 001DH | ; | Address of timer 0 data register | | TIF0 | EQU | TCR0:7 | | Defines the timer 0 interrupt request flag bit. | | ILR1 | EQU | 007BH | | Address of interrupt request setting register | | | DSEG | ABS | | [DATA SEGMENT] | | 11 <b>\1</b> _\ | ORG | 0FFF0H | , | [DATA SEGMENT] | | IDOD | | | | Sata an interment reactor | | IRQD | DW | WARI | , | Sets an interrupt vector. | | | ENDS | | | | | ; | | Main program | | | | | CSEG | | ; | [CODE SEGMENT] | | | | | ; | The stack pointer (SP), etc., is already initialized. | | | : | | | | | | CLRI | | ; | Disables the interrupt. | | | MOV | ILR1,#10111111B | ; | Sets the interrupt level to 2. | | | MOV | TCR0,#01001010B | ; | Clears the timer 0 interrupt request flag, increments the | | | | | | counter at a rising edge, selects 256t <sub>INST</sub> , and stops the | | | | | | operation. | | | MOV | TCR1,#01000010B | ; | Clears the timer 1 interrupt request flag, prohibits | | | | | | interrupt request output, sets a mode other than the 16- | | | | | | bit mode, and stops the operation. | | | MOV | TDR0,#F4H | ; | Sets the value (interval time) to be compared with the | | | | | | counter value. | #### CHAPTER 8 8/16-BIT CAPTURE TIMER/COUNTER | | MOV<br>MOV<br>SETI | TCR2,#00000010B<br>TCR0,#10101011B | ; | Outputs a square wave (TO) from the P34 pin. Allows timer 0 interrupt request output, clears the counter, and starts the timer. Enables the CPU interrupt. | |------|--------------------|------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------| | ; | | -Interrupt program | | | | WARI | CLRB | TIF0 | ; | Clears the interrupt request flag. | | | PUSHW | A | | | | | XCHW | A,T | | | | | PUSHW | A | | | | | : | | | | | | User proces | ssing | | | | | POPW | A | | | | | XCHW | A,T | | | | | POPW | A | | | | | RETI | | | | | | ENDS | | | | | ; | END | | | | ## ■ Program Example of Counter Function #### Processing specifications - In the 16-bit mode, timer 0 and timer 1 are used to generate an interrupt whenever the external clock to be input to the EC pin is counted 5,000 times (1388<sub>H</sub>). - The sample program for reading the 16-bit counter value when the counter is in operation is shown below (READ16). #### Coding example | DDR3 | EQU | 000DH | : | Address of port 3-direction register | |--------------|------|----------------------|---|-------------------------------------------------------------| | TCCR | EQU | 0019H | : | Address of capture control register | | TCR1 | EQU | 001AH | : | Address of timer 1 control register | | TCR0 | EQU | 001BH | : | Address of timer 0 control register | | TDR1 | EQU | 001CH | : | Address of timer 1 data register | | TDR0 | EQU | 001DH | : | Address of timer 0 data register | | TIF0 | EQU | TCR0:7 | : | Defines the timer 0 interrupt request flag bit. | | ILR1 | EQU | 007CH | : | Address of interrupt level setting register 2 | | INT_V | DSEG | ABS | : | [DATA SEGMENT] | | · <u>-</u> · | ORG | 0FFF0H | , | | | IRQD | DW | WARI | : | Sets the interrupt vector. | | | ENDS | | , | r | | ; | N | Aain program | | | | | CSEG | 1 0 | | [CODE SEGMENT] | | | | | ; | The stack pointer (SP), etc., is already initialized. | | | : | | | | | | MOV | DDR3,#00000000B | ; | Sets the EC pin to input. | | | CLRI | | ; | Disables the interrupt. | | | MOV | ILR1,#10111111B | ; | Sets the interrupt level to 2. | | | MOV | TDR0,#088H | ; | Sets the counter value and the lower 8 bits of the | | | | | | compare value. | | | MOV | TDR1,#013H | ; | Sets the counter value and the higher 8 bits of the | | | | | | compare value. | | | MOV | TCR1,#00001110B | ; | Sets timer 1 to 16-bit mode. | | | MOV | TCR0,#01101111B | ; | Clears the timer 0 interrupt request flag, allows interrupt | | | | | | request output, selects an external clock, clears the | | | | | | counter, starts the operation, and increments the counter | | | | | | at a rising edge. | | | SETI | | ; | Enables a CPU interrupt. | | ; | Γ | Data read subroutine | | | | READ16 | ó | | | | | | MOVW | A,TDR1 | | Reads 16 bits from TDR1 and TDR0. | | | MOVW | A,TDR1 | ; | Reads 16 bits from TDR1 and TDR0 and stores the old | | | | | | value in the T register. | | | CMPW | A | ; | Executes double read check and compares A with T. | | | BEQ | RET16 | ; | Match and return | | | | | | | #### CHAPTER 8 8/16-BIT CAPTURE TIMER/COUNTER | | XCHW | A,T | | |-------|------------|-------------------|-------------------------------------------------------------------| | | INCW | A | ; Old value + 1 | | | CMPW | A | | | | BNE | READ16 | ; Jumps to re-read when a mismatch is detected. | | RET16 | RET | | ; Restarts the count operation and begins counting 10,000 pulses. | | ; | ] | Interrupt program | | | WARI | CLRB | TIF0 | ; Clears the interrupt request flag. | | | PUSHW | A | | | | XCHW | A,T | | | | PUSHW | A | | | | : | | | | | User proce | essing | | | | : | | | | | POPW | A | | | | XCHW | A,T | | | | POPW | A | | | | RETI | | | | | ENDS | | | | ; | END | | | #### CHAPTER 8 8/16-BIT CAPTURE TIMER/COUNTER # **CHAPTER 9** # 12-BIT PPG TIMER This chapter describes the functions and operation of a 12-bit PPG timer. - 9.1 Overview of 12-bit PPG Timer - 9.2 Configuration of 12-bit PPG Timer Circuit - 9.3 Pin of 12-bit PPG Timer - 9.4 Registers of 12-bit PPG Timer - 9.5 Operations of 12-bit PPG Timer Functions - 9.6 Notes on Using 12-bit PPG Timer - 9.7 Program Example for 12-bit PPG Timer #### 9.1 Overview of 12-bit PPG Timer The 12-bit PPG timer is a 12-bit binary counter, enabling the selection of one of four types of internal count clocks. The timer is capable of setting a cycle period and "H" width of output pulse waveforms and can also be used as a remote control transmission frequency generator or 12-bit PPG. #### **■** Functions of 12-bit PPG Timer - The timer generates a frequency for remote control and outputs signals to a PPG pin. - The timer is capable of setting a cycle period and "H" width of output pulse waveforms separately. - The timer enables the selection of a count clock from four types of internal clocks. - The timer can generate a frequency in a range from twice to $2^{12}$ -1 times as fast as the counter clock. Table 9.1-1 lists the ranges in which the output pulse cycle period and "H" width are variable. Table 9.1-1 Ranges in which the Output Pulse Cycle Period and "H" Width are Variable | Internal count clock cycle period | Output pulse cycle period | Output pulse "H" width | |-----------------------------------|---------------------------------------------------|----------------------------------------------------| | 2t <sub>INST</sub> | 4t <sub>INST</sub> to 8190t <sub>INST</sub> | 2t <sub>INST</sub> to 8188t <sub>INST</sub> | | 4t <sub>INST</sub> | 8t <sub>INST</sub> to 16380t <sub>INST</sub> | 4t <sub>INST</sub> to 16376t <sub>INST</sub> | | 16t <sub>INST</sub> | $32t_{INST}$ to $65520t_{INST}$ | 16t <sub>INST</sub> to 65504t <sub>INST</sub> | | 256t <sub>INST</sub> | 512t <sub>INST</sub> to 1048.32kt <sub>INST</sub> | 256t <sub>INST</sub> to 1048.064kt <sub>INST</sub> | $t_{\mbox{\footnotesize{INST:}}}$ Instruction cycle (to be affected by a gear function) #### Note: An example of calculating the output pulse cycle period and "H" width as executed by a 12-bit PPG function is given below. When an oscillation ( $F_{CH}$ ) of 12.5 MHz and a count clock cycle period of 2 $t_{INST}$ are set, and if: Compare value for cycle period = $011110_{\rm R}$ (30-clock period) Compare value for "H" width = 001010<sub>B</sub> (10-clock width) Then, "H" width and the cycle period of output pulse waveforms are calculated as given below. These calculations are obtained provided the system clock control register (SYCC) selects the fastest clock (CS1, CS0 = $11_B$ with one instruction cycle = $4/F_{CH}$ ). Cycle period = Compare value for cycle period $$\times$$ Count clock cycle period = 011110<sub>H</sub> (30-clock period) $\times$ 2 $\times$ 4/F<sub>CH</sub> = 30 $\times$ 2 $\times$ 0.32 $\mu$ s = 19.2 $\mu$ s "H" width = Compare value for "H" width $\times$ Count clock cycle period = 001010<sub>B</sub> (10-clock width) $\times$ 2 $\times$ 4/F<sub>CH</sub> If the set "H" width is equal to or greater than the set cycle period, "H" level outputs occur. #### ■ 12-bit PPG Function The timer's programmable pulse output generator function can be used as a 12-bit PPG because it can set a cycle period and "H" pulse width of output pulse waveforms separately. A range of controllable duty cycles is 0.02% to 100%. However, the smaller the compare value for the cycle period, the lower the resolution (the greater a minimum-step duty cycle). If the compare value for the cycle period is "2", a comparative setting of "H" pulse width is 1 or 2 (a duty cycle of 50% or 100%) and the resolution is 1/2. An output frequency and a duty cycle can be calculated using the following equations: Output pulse cycle period = Compare value for cycle period × Count clock cycle period Duty cycle = Compare value for "H" width/Compare value $\times$ 100(%) =10 $\times$ 2 $\times$ 0.32 $\mu$ s $=6.4 \mu s$ Table 9.1-2 lists available resolution values, minimum-step duty cycles, and output pulse cycle periods. Table 9.1-2 Resolutions and Output Pulse Cycle Periods Supported when the Timer is Used as a 12-bit PPG (1/2) | Compare | value for cycle available compare cycle Count clock Count c | | Output puls | | Minimum- | | | |---------|-------------------------------------------------------------|----------------------|--------------------------------------|------------------------------------------------------------------------|------------------------|------------|--------------------| | cycle | | | Count clock<br>= 4 t <sub>INST</sub> | Count clock Count clock = 16 t <sub>INST</sub> = 256 t <sub>INST</sub> | | Resolution | step duty<br>cycle | | 0 | - | | | Unavai | labla | | | | 1 | - | | | Ullavai | iable | | | | 2 | 1, 2 | 4 t <sub>INST</sub> | 8 t <sub>INST</sub> | 32 t <sub>INST</sub> | 512 t <sub>INST</sub> | 1/2 | 50.0% | | 3 | 1 to 3 | 6 t <sub>INST</sub> | 12 t <sub>INST</sub> | 48 t <sub>INST</sub> | 768 t <sub>INST</sub> | 1/3 | 33.3% | | 4 | 1 to 4 | 8 t <sub>INST</sub> | 16 t <sub>INST</sub> | 64 t <sub>INST</sub> | 1024 t <sub>INST</sub> | 1/4 | 25.0% | | 5 | 1 to 5 | 10 t <sub>INST</sub> | 20 t <sub>INST</sub> | 80 t <sub>INST</sub> | 1280 t <sub>INST</sub> | 1/5 | 20.0% | | 6 | 1 to 6 | 12 t <sub>INST</sub> | 24 t <sub>INST</sub> | 96 t <sub>INST</sub> | 1536 t <sub>INST</sub> | 1/6 | 16.7% | | 7 | 1 to 7 | 14 t <sub>INST</sub> | 28 t <sub>INST</sub> | 112 t <sub>INST</sub> | 1792 t <sub>INST</sub> | 1/7 | 14.3% | | 8 | 1 to 8 | 16 t <sub>INST</sub> | 32 t <sub>INST</sub> | 128 t <sub>INST</sub> | 2048 t <sub>INST</sub> | 1/8 | 12.5% | Table 9.1-2 Resolutions and Output Pulse Cycle Periods Supported when the Timer is Used as a 12-bit PPG (2/2) | Compare | Range of available | | Output puls | se cycle period | | | Minimum- | |------------------------------|-----------------------------|------------------------|----------------------------------------------------------------------|-------------------------|----------------------------------------|------------|--------------------| | value for<br>cycle<br>period | compare compare count clock | | Count clock = 4 t <sub>INST</sub> Count clock = 16 t <sub>INST</sub> | | Count clock<br>= 256 t <sub>INST</sub> | Resolution | step duty<br>cycle | | 9 | 1 to 9 | 18 t <sub>INST</sub> | 36 t <sub>INST</sub> | 144 t <sub>INST</sub> | 2304 t <sub>INST</sub> | 1/9 | 11.1% | | 10 | 1 to 10 | 20 t <sub>INST</sub> | 40 t <sub>INST</sub> | 160 t <sub>INST</sub> | 2560 t <sub>INST</sub> | 1/10 | 10.0% | | | | : | : | : | : | | | | 20 | 1 to 20 | 40 t <sub>INST</sub> | 80 t <sub>INST</sub> | 320 t <sub>INST</sub> | 5120 t <sub>INST</sub> | 1/20 | 5.0% | | | | : | : | : | : | | | | 100 | 1 to 100 | 200 t <sub>INST</sub> | 400 t <sub>INST</sub> | 1600 t <sub>INST</sub> | 25600 t <sub>INST</sub> | 1/100 | 1.0% | | | | : | : | : | : | | | | 500 | 1 to 500 | 1000 t <sub>INST</sub> | 2000 t <sub>INST</sub> | 8000 t <sub>INST</sub> | 128000 t <sub>INST</sub> | 1/500 | 0.2% | | | | : | : | : | : | | | | 1000 | 1 to 1000 | 2000 t <sub>INST</sub> | 4000 t <sub>INST</sub> | 16000 t <sub>INST</sub> | 256000 t <sub>INST</sub> | 1/1000 | 0.1% | | | | : | : | : | : | | | | 2000 | 1 to 2000 | 4000 t <sub>INST</sub> | 8000 t <sub>INST</sub> | 32000 t <sub>INST</sub> | 512000 t <sub>INST</sub> | 1/2000 | 0.05% | | | | : | : | : | : | | | | 3000 | 1 to 3000 | 6000 t <sub>INST</sub> | 12000 t <sub>INST</sub> | 48000 t <sub>INST</sub> | 768000 t <sub>INST</sub> | 1/3000 | 0.03% | | | | : | : | : | : | | | | 4095 | 1 to 4095 | 8190 t <sub>INST</sub> | 16380 t <sub>INST</sub> | 65520 t <sub>INST</sub> | 1048320 t <sub>INST</sub> | 1/4095 | 0.02% | t<sub>INST</sub>: Instruction cycle # 9.2 Configuration of 12-bit PPG Timer Circuit The 12-bit PPG timer comprises the following seven blocks: - Count clock selector - 12-bit counter - Comparator - 12-bit PPG control register 1 (RCR21) - 12-bit PPG control register 2 (RCR22) - 12-bit PPG control register 3 (RCR23) - 12-bit PPG control register 4 (RCR24) #### ■ Block Diagram of 12-bit PPG Timer Figure 9.2-1 Block Diagram of 12-bit PPG Timer #### CHAPTER 9 12-BIT PPG TIMER #### Count clock selector This selector circuit selects one of four types of internal count clocks as the count-up clock for a 12-bit counter. #### 12-bit counter The 12-bit counter executes a count-up operation based on the count clock selected by the count clock selector. This counter may be cleared according to the value of the output enable bit of the RCR23 register (RCR23:RCEN=0). #### Comparator The comparator maintains outputs at "H" until a count by the 12-bit counter has been synchronized with the value of the register containing the compare value for "H" width. The comparator then maintains outputs at "L" until a count by the counter is synchronized with the value of the register containing the set cycle period. At this time, the 12-bit counter is cleared and restarts to count from " $00_H$ ". #### • 12-bit PPG control registers 1 (RCR21) and 2 (RCR22) These registers comprise bits for count clock selection and bits for setting a compare value for the "H" width. #### 12-bit PPG control registers 3 (RCR23) and 4 (RCR24) These registers comprise a bit for specifying whether to enable or disable the 12-bit PPG output and bits for setting a compare value for the cycle period. #### 9.3 Pin of 12-bit PPG Timer This section describes the pin associated with the 12-bit PPG timer and illustrates a block diagram of circuitry terminating at the pin. #### ■ Pin Associated with the 12-bit PPG Timer The pin associated with the 12-bit PPG timer is P37/BZ/PPG pin. #### • P37/BZ/PPG pin This pin functions as a CMOS type (P37) general-purpose I/O port, further functioning as 12-bit PPG timer output (PPG). PPG: By setting the output enable bit of the appropriate 12-bit PPG control register (RCR23:RCEN) to "1", the pin functions as the PPG output pin through which the set cycle period and "H" width of PPG pulse waveforms are output. # ■ Block Diagram of Circuitry Terminating at the Pin Associated with the 12-bit PPG Timer **PDR** Stop mode (SPL = 1) Pull-up resistor PDR read Output from peripheral C Output enabl from peripheral snq PDR read (when read-modify-write is datal performed) P-ch nternal Output latch 0 PDR write Pin P37/BZ/PPG N-ch **DDR** DDR write 7/7 Stop mode (SPL = 1) PUL read PUL PUL write Figure 9.3-1 Block Diagram of Circuitry Terminating at the P37/BZ/PPG Pin #### **Notes:** - If the ON setting of the pull-up resistor is selected by the pull-up setting register, the pin state will be the "H" level (pull-up state) in stop mode (SPL = 1). - Because buzzer outputs to the P37/BZ/PPG pin precede 12-bit PPG outputs to this pin, if the pin is used as the PPG pin, turn the buzzer outputs off and set the RCEN bit such that PPG outputs are enabled. # 9.4 Registers of 12-bit PPG Timer This section describes the registers associated with the 12-bit PPG timer. ## ■ Registers Associated with 12-bit PPG Timer Figure 9.4-1 Registers Associated with 12-bit PPG Timer | RCR21 (12-bit PPG control register 1) | | | | | | | | | | |-----------------------------------------|---------|-----------|-----------|-------|------|------|------|------|-----------------------| | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0014 <sub>H</sub> | RCK1 | RCK0 | HSC5 | HSC4 | HSC3 | HSC2 | HSC1 | HSC0 | 00000000 <sub>B</sub> | | | R/W | | RCR22 (12-bit | t PPG c | ontrol re | egister 2 | 2) | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0015 <sub>H</sub> | _ | _ | HSC11 | HSC10 | HSC9 | HSC8 | HSC7 | HSC6 | 000000 <sub>B</sub> | | | | | R/W | R/W | R/W | R/W | R/W | R/W | | | RCR23 (12-bit | PPG co | ontrol re | egister 3 | ) | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0016 <sub>Н</sub> | RCEN | _ | SCL5 | SCL4 | SCL3 | SCL2 | SCL1 | SCL0 | 0-000000 <sub>B</sub> | | | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | | RCR24 (12-bit | PPG co | ontrol re | egister 4 | ) | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0017 <sub>H</sub> | | _ | SCL11 | SCL10 | SCL9 | SCL8 | SCL7 | SCL6 | 000000 <sub>B</sub> | | | | | R/W | R/W | R/W | R/W | R/W | R/W | , | | R/W : Readable and Writable — : Unused | | | | | | | | | | # 9.4.1 12-bit PPG Control Register 1 (RCR21) The 12-bit PPG control register 1 comprises bits for count clock selection of the 12-bit PPG timer and bits for setting the "H" width. #### ■ 12-bit PPG Control Register 1 (RCR21) Address bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 Initial value 0014H RCK1 RCK0 HSC5 HSC4 HSC3 HSC2 HSC1 HSC0 00000000B R/W R/W R/W R/W R/W R/W R/W R/W HSC5 to HSC0 "H" width setting bits XXXXXX Compare value for the "H" width of 12-bit PPG outputs. RCK1 RCK0 Count clock selection bits 0 0 $2 t_{\text{INST}}$ $4 t_{INST}$ 0 1 $16 t_{INST}$ 1 0 256 t<sub>INST</sub> 1 R/W: Readable/Writable : Initial value Figure 9.4-2 12-bit PPG Control Register 1 (RCR21) Table 9.4-1 Explanation of Functions of Each Bit in 12-bit PPG Control Register 1 (RCR21) | Bit name | | Function | |--------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7,<br>bit6 | RCK1, RCK0:<br>Count clock<br>selection bits | These bits are used to select a count clock of the 12-bit PPG timer from four types of internal count clocks. | | bit5<br>to<br>bit0 | HSC5 to HSC0: "H" width setting bits | These bits are used to set the number of counts corresponding to the "H" width of 12-bit PPG timer outputs (the compare value for the "H" width), and the contents of these bits and the HSC6 to HSC11 bits of the RCR22 register are compared with a count by the counter. | # 9.4.2 12-bit PPG Control Register 2 (RCR22) The 12-bit PPG control register 2 comprises bits for setting the "H" width of 12-bit PPG pulse waveforms. #### ■ 12-bit PPG Control Register 2 (RCR22) Figure 9.4-3 12-bit PPG Control Register 2 (RCR22) Table 9.4-2 Explanation of Functions of Each Bit in 12-bit PPG Control Register 2 (RCR22) | В | it name | Function | |--------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7,<br>bit6 | Unused bits | <ul> <li>Bit value is undefined when being read.</li> <li>Written value does not affect other operations.</li> </ul> | | bit5<br>to<br>bit0 | HSC11 to HSC6: "H" width setting bits | These bits are used to set the number of counts corresponding to the "H" width of 12-bit PPG timer outputs (the compare value for the "H" width), and the contents of these bits and the HSC0 to HSC5 bits of the RCR21 register are compared with a count by the counter. | # 9.4.3 12-bit PPG Control Register 3 (RCR23) The 12-bit PPG control register 3 comprises a bit for enabling 12-bit PPG waveform outputs and bits for setting a cycle period of outputs. #### ■ 12-bit PPG Control Register 3 (RCR23) Figure 9.4-4 12-bit PPG Control Register 3 (RCR23) Table 9.4-3 Explanation of Functions of Each Bit in 12-bit PPG Control Register 3 (RCR23) | В | it name | Function | | | | |--------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | bit7 | RCEN:<br>Output enable bit | When this bit is "0", the P37/BZ/PPG pin functions as a general-purpose port (P37); when the bit is "1", the pin functions as a 12-bit PPG output pin (PPG). When "0" is written for this bit, the counter is cleared and its operation stops; when "1" is written, the count operation starts. Even if PPG outputs are enabled by this bit setting, buzzer outputs, if enabled, have priority. | | | | | bit6 | Unused bit | <ul> <li>Bit value is undefined when being read.</li> <li>Written value does not affect other operations.</li> </ul> | | | | | bit5<br>to<br>bit0 | SCL5 to SCL0:<br>Cycle period<br>setting bits | These bits are used to set the number of counts corresponding to the cycle period of 12-bit PPG waveform outputs (the compare value for the cycle period), and the contents of these bits and the SCL6 to SCL11 bits of RCR24 are compared with a count by the counter. Note: | | | | #### Note: Because buzzer outputs to the P37/BZ/PPG pin precede 12-bit PPG outputs to this pin, if the pin is used as the PPG pin, turn the buzzer outputs off and set the RCEN bit such that PPG outputs are enabled. # 9.4.4 12-bit PPG Control Register 4 (RCR24) The 12-bit PPG control register 4 comprises bits for setting a cycle period of 12-bit PPG waveform outputs. #### ■ 12-bit PPG Control Register 4 (RCR24) Figure 9.4-5 12-bit PPG Control Register 4 (RCR24) Table 9.4-4 Explanation of Functions of Each Bit in 12-bit PPG Control Register 4 (RCR24) | В | it name | Function | |--------------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7,<br>bit6 | Unused bits | <ul> <li>Bit value is undefined when being read.</li> <li>Written value does not affect other operations.</li> </ul> | | bit5<br>to<br>bit0 | SCL11 to SCL6:<br>Cycle period<br>setting bits | These bits are used to set the number of counts corresponding to the cycle period of 12-bit PPG waveform outputs (the compare value for cycle period), and the contents of these bits and the SCL0 to SCL5 bits of RCR23 are compared with a count by the counter. Note: | ## 9.5 Operations of 12-bit PPG Timer Functions The 12-bit PPG timer can be used as a 12-bit PPG because the output pulse cycle period and "H" pulse width can be set separately. #### **■** Example of Operations of 12-bit PPG Timer Functions To operate the 12-bit PPG timer, the bits of the registers must be set as shown in Figure 9.5-1. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 RCR21 RCK1 RCK0 HSC5 HSC4 HSC3 HSC2 HSC1 HSC0 0 0 0 0 0 0 RCR22 HSC11 HSC10 HSC9 HSC8 HSC7 HSC6 RCR23 RCEN SCL5 SCL4 SCL3 SCL2 SCL1 SCL0 1 0 0 0 0 0 0 SCL10 SCL9 SCL8 SCL7 SCL6 RCR24 SCL11 0 0 0 0 0 $\bigcirc$ (iii): Used bit 1 : Set "1" Figure 9.5-1 Setting 12-bit PPG Timer When 12-bit PPG outputs are enabled, the 12-bit counter starts counting from " $000_{H^{"}}$ in synchronization with the selected count clock and the PPG pin is maintained at "H" level until a count by the counter is synchronized with the compare value for the "H" width. The PPG pin is then maintained at "L" level until a count by the counter is synchronized with the compare value for the cycle period. At this time, the 12-bit counter is cleared and restarts counting from " $000_{H^{"}}$ . Because the "H" width and cycle period can be set separately, the timer can be used as a 12-bit PPG. Figure 9.5-2 illustrates the operation of the 12-bit PPG timer. Figure 9.5-2 Operation of 12-bit PPG Timer ## 9.6 Notes on Using 12-bit PPG Timer #### This section provides notes on using the 12-bit PPG timer. #### ■ Notes on Using 12-bit PPG Timer #### Output pin changeover The P37/BZ/PPG pin shares functions of a general-purpose port and a 12-bit PPG output. Because its buzzer output (BZ) function precedes the 12-bit PPG output function, if buzzer outputs are enabled, it functions as the buzzer output (BZ) pin even if PPG outputs are enabled by the RCR23 (RCEN bit). To use it as the 12-bit PPG output (PPG) pin, turn the buzzer outputs OFF. #### Limitation of "H" width setting Using the "H" width setting bits of the 12-bit PPG control registers 1 and 2 (RCR21:HSC5 to HSC0 and RCR22:HSC11 to HSC6), set a value that falls within the range of "000000000000 $^{1}$ B" to "111111111111 $^{1}$ B" (001 $^{1}$ H to FFF $_{H}$ ). If "000 $^{1}$ H" is set, "H" level outputs are delivered through the PPG pin. Furthermore, set the value of the "H" width so as to be smaller than the value given by the cycle period setting bits of 12-bit PPG control registers 3 and 4 (RCR23:SCL5 to SCL0 and RCR24:SCL11 to SCL6). If the "H" width is equal to or greater than the cycle period, "H" level outputs are always delivered through the PPG pin. #### Resolution When the cycle period is set at "111111111111 $_{\rm B}$ " (FFF<sub>H</sub>), a maximum "H" width resolution of 1/4095 is obtained. This resolution is reduced as the cycle period setting becomes smaller and limited to a minimum of 1/2 when the cycle period is set at "000000000010<sub>B</sub>" (002<sub>H</sub>). #### Setting change during operation The "H" width setting bits (RCR21:HSC5 to HSC0 and RCR22:HSC11 to HSC6) and the cycle period setting bits (RCR23:SCL5 to SCL0 and RCR24:SCL11 to SCL6) are compared with the 12-bit counter for generating a frequency of 12-bit PPG waveforms. If the set values given by these bits are changed to smaller values during the operation of the counter, a counter overflow occurs, which may extend the cycle period until synchronization with a count by the counter is detected again. Similarly, this may extend the "H" width until synchronization with a count by the counter is detected in the next cycle (cycle period). Figure 9.6-1 illustrates setting change during the operation of the 12-bit PPG timer. Figure 9.6-1 Setting Change during 12-bit PPG Timer Operation #### Error Because the counter start by program is asynchronous with the count-up start by the selected count clock, an error (a time difference) may occur until detection of synchronization of compare values for the "H" width and for the cycle period with a count by the counter. A major error may shorten the time before the above synchronization to one count clock cycle. Figure 9.6-2 illustrates an error (a time difference) before the count operation start. Figure 9.6-2 Error before Count Operation Start # 9.7 Program Example for 12-bit PPG Timer #### An example of 12-bit PPG timer programming is given below. #### ■ Program Example for 12-bit PPG Timer #### Processing specification - A remote control transmission frequency with a period of about 38 μs and a duty cycle of approx. 33% is generated. - The compare value for the PPG output pulse cycle period giving the above period of about 38 μs at the maximum gear speed with oscillation of 12.5 MHz (F<sub>CH</sub>) is determined as below. The count clock is assumed to be 4 t<sub>INST</sub>. - Compare value for cycle period (RCR23:SCL5 to SCL0 and RCR24:SCL11 to SCL6) = 38 $\mu$ s/ (4 $\times$ 4/10MHz) = 30 - The compare value for the "H" width of the PPG output pulse giving the duty cycle of approx. 33% is determined as below. At this time, the "H" width is about 3 µs. - Compare value for the "H" width (RCR21:HSC5 to HSC0 and RCR22:HSC11 to HSC6) = $33/100 \times$ Compare value for the cycle period = $0.33 \times 30 = 10$ #### Coding example | RCR21 EQU<br>RCR22 EQU<br>RCR23 EQU<br>RCR24 EQU | 0014H<br>0015H<br>0016H<br>0017H | ;;;; | Address of 12-bit PPG control register 1 Address of 12-bit PPG control register 2 Address of 12-bit PPG control register 3 Address of 12-bit PPG control register 4 | |--------------------------------------------------|----------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ,<br>CSEG<br>: | Wain program | ; | [CODE SEGMENT] | | MOV | RCR21,#01001010B | ; | Select count clock of 4 $t_{\mbox{INST}}$ and set the above compare value for "H" width. | | MOV | RCR22,#00H | ; | | | MOV | RCR23,#10011110B | ; | Specify outputs enabled and counter operation start and set the above compare value for cycle period. | | MOV<br>: | RCR24,#00H | ; | | | ENDS | | | | | ,<br>END | | | | #### CHAPTER 9 12-BIT PPG TIMER # CHAPTER 10 # EXTERNAL INTERRUPT CIRCUIT 1 (EDGE) This chapter describes the function and operation of external interrupt circuit 1 (edge). - 10.1 Overview of External Interrupt Circuit 1 - 10.2 Configuration of External Interrupt Circuit 1 - 10.3 Pins of External Interrupt Circuit 1 - 10.4 Registers of External Interrupt Circuit 1 - 10.5 Interrupt of External Interrupt Circuit 1 - 10.6 Operations of External Interrupt Circuit 1 - 10.7 Program Example for External Interrupt Circuit 1 ## 10.1 Overview of External Interrupt Circuit 1 External interrupt circuit 1 detects a predetermined edge or edges of a signal input to any of three external interrupt pins and then generates and issues an interrupt request to the CPU. #### **■ Functions of External Interrupt Circuit 1** The external interrupt circuit 1 functions to detect an optionally selected edge or edges of a signal input to any of the external interrupt pins and then generate and issue an interrupt request to the CPU. This interrupt ensures recovery from standby mode and enables transition to a normal operating state (main clock operation mode). - External interrupt pins: Three pins (P34/TO/INT10 to P36/INT12) - External interrupt triggering: Input of a signal with an optionally selected edge or edges (rising and/or falling edges) to one of the above external interrupt pins triggers an external interrupt. - Interrupt control: Interrupt request outputs are enabled or disabled according to the content of an interrupt request enable bit of external interrupt 1 control registers 1 and 2 (EIC1, EIC2). - Interrupt flag: Detection of specified edge or edges is indicated by an external interrupt request flag bit of external interrupt 1 control registers 1 and 2 (EIC1, EIC2). - Interrupt request: An interrupt request is generated according to the pin at which the input of the signal triggering an external interrupt is detected (IRQ0, IRQ1, IRQ2). # 10.2 Configuration of External Interrupt Circuit 1 External interrupt circuit 1 comprises the following two blocks: - Edge detecting circuits (0 to 2) - External interrupt control 1 registers 1, 2 (EIC1, EIC2) #### ■ Block Diagram of External Interrupt Circuit 1 Figure 10.2-1 Block Diagram of External Interrupt Circuit 1 (EIC1, EIC2) #### CHAPTER 10 EXTERNAL INTERRUPT CIRCUIT 1 (EDGE) #### Edge detecting circuits When the edge polarity of a signal input to one of the pins (INT10 to INT12) for external interrupt circuit 1 matches the selected edge polarity for the pin, stored in either the EIC1 or EIC2 registers in the appropriate bit position (SL00 to SL21), one of the external interrupt request flag bits (EIR0 to EIR2) corresponding to the pin is set to "1". #### External interrupt 1 control registers (EIC1, EIC2) The EIC1 and EIC2 registers comprise bits for edge selection, for enabling or disabling interrupt requests, and for confirming an interrupt request. #### Triggers that cause external interrupt circuit 1 to generate an interrupt request - IRQ0: When a signal with an edge or edges corresponding to the selected edge polarity is input to the INT10 pin for external interrupt circuit 1, if interrupt request outputs are enabled (EIC1:EIE0=1), external interrupt circuit 1 generates an IRQ0 interrupt request. - IRQ1: When a signal with an edge or edges corresponding to the selected edge polarity is input to the INT11 pin for external interrupt circuit 1, if interrupt request outputs are enabled (EIC1:EIE1=1), external interrupt circuit 1 generates an IRQ1 interrupt request. - IRQ2: When a signal with an edge or edges corresponding to the selected edge polarity is input to the INT12 pin for external interrupt circuit 1, if interrupt request outputs are enabled (EIC2:EIE2=1), external interrupt circuit 1 generates an IRQ2 interrupt request. # 10.3 Pins of External Interrupt Circuit 1 This section describes the pins associated with external interrupt circuit 1 and illustrates a block diagram of circuitry terminating at the pins with reference to the registers and external interrupt triggering. #### ■ Pins Associated with External Interrupt Circuit 1 The pins associated with external interrupt circuit 1 are the P34/TO/INT10 to P36/INT12 pins. #### ● P34/TO/INT10 pin This pin functions as a general-purpose I/O dedicated port and may also serve 8/16-bit capture timer outputs (TO) and external interrupt inputs (hysteresis inputs) (INT10). If the timer 1 control register (TCR0) disables 8/16-bit capture timer outputs and, by the port data direction register (DDR3), the pin is set to function as an input port only. The pin can also function as an external interrupt input pin (INT10). When external interrupt 1 control register 1 (EIC1) sets edge detection to OFF, however, no external interrupt requests are generated, and when interrupt request outputs are disabled, no interrupt requests are output. The pin state can be read directly from the port data register (PDR3) at any time. #### P35/INT11 and P36/INT12 pins These pins function as a general-purpose I/O dedicated port (P35, P36) and may also serve external interrupt inputs (hysteresis inputs) (INT11, INT12). If, by the port data direction register (DDR3), these pins are set to function as an input port only, they also function as external interrupt input pins (INT11, INT12). When external interrupt 1 control registers 1 and 2 (EIC1, EIC2) set edge detection to OFF, however, no external interrupt requests are generated, and when interrupt request outputs are disabled, no interrupt requests are output. The pin state can be read directly from the port data register (PDR3) at any time. Table 10.3-1 lists the pins associated with external interrupt circuit 1. Table 10.3-1 Pins Associated with External Interrupt Circuit 1 | External interrupt pin | Use for external interrupt input (Interrupt request output enabled) | Use for input port only (Interrupt request output or edge detection disabled) | | |------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------|--| | P34/TO/INT10 | INT10 (EIC1:EIE0=1, DDR3:bit4=0, TCR2:PEN=0) | P34(EIC1:EIE0=0 or SL01, SL00=00 <sub>B</sub> ) | | | P35/INT11 | INT11 (EIC1:EIE1=1, DDR3:bit5=0) | P35(EIC1:EIE1=0 or SL11, SL10=00 <sub>B</sub> ) | | | P36/INT12 | INT12 (EIC2:EIE2=1, DDR3:bit6=0) | P36(EIC2:EIE2=0 or SL21, SL20=00 <sub>B</sub> ) | | INT10 to INT12: When a signal with an edge or edges corresponding to the selected edge polarity is input to these pins, an interrupt corresponding to the pin is generated. # ■ Block Diagram of Circuitry Terminating at the Pins Associated with External Interrupt Circuit 1 External interrupt INT10,INT11 enable "INT12 ← **PDR** Stop mode (SPL=1) Output from peripheral Output from peripheral Output from peripheral from peripheral PDR read Pull-up resistor Internal data bus PDR read (when read-modify-write is performed) Output latch P-ch PDR write Pins P34/TO/INT10 P35/INT11 N-ch DDR P36/INT12 DDR write カケ Stop mode (SPL=1) PUL read PUL PUL write Figure 10.3-1 Block Diagram of Circuitry Terminating at the Pins Associated with External Interrupt Circuit 1 #### Note: When the ON setting of the pull-up resistor is selected by the pull-up setting register, the pin state will be "H" level (pull-up state) rather than Hi-Z during stop mode (SPL = 1). During a reset, however, the pull-up is invalid and the pin remains at Hi-Z. # 10.4 Registers of External Interrupt Circuit 1 This section describes the registers associated with external interrupt circuit 1. ■ Registers Associated with External Interrupt Circuit 1 Figure 10.4-1 Registers Associated with External Interrupt Circuit 1 ## 10.4.1 External Interrupt Control Register 1 (EIC1) External interrupt control register 1 (EIC1) comprises bits for edge polarity selection and interrupt control for the INT10 and INT11 external interrupt pins. #### **■** External Interrupt Control Register 1 (EIC1) Figure 10.4-2 External Interrupt Control Register 1 (EIC1) Table 10.4-1 Explanation of Functions of Each Bit in External Interrupt Control Register 1 (EIC1) (1/2) | Bit name | | Function | |---------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | EIR1:<br>External interrupt<br>request flag bit1 | <ul> <li>When a signal with an edge or edges corresponding to edge polarity selected by edge polarity selection bits (SL11, SL10) is input to INT11 external interrupt pin, this bit is set to "1".</li> <li>When this bit and interrupt request enable bit 1 (EIE1) are "1", the interrupt request is output.</li> <li>Writing "0" clears this bit; writing "1" does not affect this bit (no change).</li> </ul> | | bit6,<br>bit5 | SL11, SL10:<br>Edge polarity<br>selection bits 1 | <ul> <li>These bits are used to select the polarity of an edge or edges of a signal pulse that triggers an interrupt when the signal is input to INT11 external interrupt pin.</li> <li>When these bits provide a value of "00<sub>B</sub>", edge detection is not performed and interrupt requests are not generated.</li> <li>These bits may specify "01<sub>B</sub>", indicating a rising edge, "10<sub>B</sub>", a falling edge, or "11<sub>B</sub>", both edges to be detected.</li> <li>Note: If an edge is selected while edge detection is OFF, edge detection may be performed unconditionally. Always clear the EIR0 bit after selecting an edge.</li> </ul> | | bit4 | EIE1:<br>Interrupt request<br>enable bit 1 | This bit enables or disables interrupt request outputs to CPU. When this bit and external interrupt request flag bit 1 (EIR1) are "1", the interrupt request is output. <b>Notes:</b> • When using the external interrupt pin, write "0" for bit5 of the port data direction register (DDR3) so that the pin serves inputs only. • Regardless of the interrupt request enable bit state, the state of the external interrupt pin can be read directly from the port data register (PDR3). | | bit3 | EIR0:<br>External interrupt<br>request flag bit 0 | <ul> <li>When a signal with an edge or edges corresponding to edge polarity selected by edge polarity selection bits (SL01, SL00) is input to INT10 external interrupt pin, this bit is set to "1".</li> <li>When this bit and interrupt request enable bit 0 (EIE0) are "1", the interrupt request is output.</li> <li>Writing "0" clears this bit, and writing "1" does not affect this bit.</li> </ul> | | bit2,<br>bit1 | SL01, SL00:<br>Edge polarity<br>selection bits 0 | <ul> <li>These bits are used to select the polarity of an edge or edges of a signal pulse that triggers an interrupt when the signal is input to the INT10 external interrupt pin.</li> <li>When these bits provide a value of "00<sub>B</sub>", edge detection is not performed and interrupt requests are not generated.</li> <li>These bits may specify "01<sub>B</sub>", indicating a rising edge, "10<sub>B</sub>", a falling edge, or "11<sub>B</sub>", both edges to be detected.</li> <li>Note: If edge is selected when edge detection is OFF, edge detection may be performed unconditionally. Always clear the EIR0 bit after selecting an edge.</li> </ul> | Table 10.4-1 Explanation of Functions of Each Bit in External Interrupt Control Register 1 (EIC1) (2/2) | Bit name | | Function | | |----------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | bit0 | EIE0:<br>Interrupt request<br>enable bit 0 | <ul> <li>This bit enables or disables interrupt request outputs to the CPU. When this bit and external interrupt request flag bit 0 (EIR0) are "1", the interrupt request is output.</li> <li>Notes:</li> <li>When using the external interrupt pin, write "0" for bit4 of the port data direction register (DDR3) so that the pin serves inputs only. Write "0" for bit1 of the timer output control register (TCR2) for the 8/16-bit capture timer/counter to set the port input function on.</li> <li>Regardless of the interrupt request enable bit state, the state of the external interrupt pin can be read directly from the port data register (PDR3).</li> </ul> | | # 10.4.2 External Interrupt Control Register 2 (EIC2) As with external interrupt control register 1 (EIC1), external interrupt control register 2 (EIC2) comprises bits for edge polarity selection and interrupt control for the INT12 external interrupt pin. **■** External Interrupt Control Register 2 (EIC2) Figure 10.4-3 External Interrupt Control Register 2 (EIC2) Table 10.4-2 Explanation of Functions of Each Bit in External Interrupt Control Register 2 (EIC2) | Bit name | | Function | | |--------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | bit7<br>to<br>bit4 | Unused bits | <ul> <li>Bit value is undefined when being read.</li> <li>Written value does not affect other operations.</li> </ul> | | | bit3 | EIR2:<br>External interrupt<br>request flag bit 2 | <ul> <li>When a signal with an edge or edges corresponding to edge polarity selected by edge polarity selection bits 2 (SL21, SL20) is input to the INT12 external interrupt pin, this bit is set to "1".</li> <li>When this bit and interrupt request enable bit 2 (EIE2) are "1", the interrupt request is output.</li> <li>Writing "0" clears this bit, and writing "1" does not affect this bit (no change).</li> </ul> | | | bit2<br>bit1 | SL21, SL20:<br>Edge polarity selection<br>bits 2 | <ul> <li>These bits are used to select the polarity of an edge or edges of a signal pulse that triggers an interrupt when the signal is input to the INT12 external interrupt pin.</li> <li>When these bits provide a value of "00<sub>B</sub>", edge detection is not performed and interrupt requests are not generated.</li> <li>These bits may specify "01<sub>B</sub>", indicating a rising edge, "10<sub>B</sub>", a falling edge, or "11<sub>B</sub>", both edges to be detected.</li> <li>Note: If edge is selected while edge detection is OFF, edge detection may be performed unconditionally. Always clear EIR2 bit after selecting an edge.</li> </ul> | | | bit0 | EIE2:<br>Interrupt request<br>enable bit 2 | This bit enables or disables interrupt request outputs to the CPU. When this bit and external interrupt request flag bit 2 (EIR2) are "1", the interrupt request is output. Notes: When using the external interrupt pin, write "0" for bit6 of the port data direction register (DDR3) so that the pin serves inputs only. Regardless of the interrupt request enable bit state, the state of external interrupt pin can be read directly from the port data register (PDR3). | | ## 10.5 Interrupt of External Interrupt Circuit 1 The detection of a signal with the specified edge or edges, input to any of the external interrupt pins, triggers external interrupt circuit 1 to generate an interrupt request. #### ■ Interrupt during the Operation of External Interrupt Circuit 1 When external interrupt circuit 1 detects the specified edge or edges of external interrupt input at a pin, an external interrupt request flag bit (EIC1, EIC2:EIR0 to EIR2) corresponding to the pin is set to "1". At this time, if the interrupt request enable bit corresponding to the pin contains the value indicating the enabled state (EIC1, EIC2:EIE0 to EIE2=1), the external interrupt circuit 1 generates and then issues the appropriate interrupt request (IRQ0, IRQ1, IRQ2) to the CPU. Write "0" for the external interrupt request flag bit within the interrupt processing routine for the interrupt request, thus clearing the interrupt request. If external interrupts are not used for recovery from stop mode, set the edge polarity selection bits to " $00_B$ " and the interrupt enable bits to "0". #### **Notes:** - When edge detection OFF is selected and set with edge polarity selection bits, the occurring input is held as is before entry to the internal edge detecting circuit. If edge is selected during the edge detection OFF state, edge detection may be performed unconditionally with the external interrupt request flag bit set to "1". - When interrupts are set enabled (EIC1, EIC2:EIE0 to EIE2=1) after the release from the reset state, clear the appropriate external interrupt request flag bit (EIR0 to EIR2=0) at the same time. - If the external interrupt request flag bit is "1" with the interrupt request enable bit containing a value indicating enable state, a return from the interrupt processing is not possible. Always clear the external interrupt request flag bit within the interrupt processing routine. - For edge selection during the edge detection OFF state, specify an edge or edges when interrupt request outputs are disabled and then clear the external interrupt request flag bit. - Regardless of the value of the appropriate interrupt request enable bit (EIE0 to EIE2), the external interrupt request flag bit is set to "1" whenever edge polarity matching is detected. - Only external interrupt circuits 1 and 2 can execute a release from stop mode by an interrupt. - With the external interrupt request flag bit being set to "1", when the interrupt request enable bit setting changes from disable to enable $(0 \rightarrow 1)$ , an interrupt request is generated immediately. # ■ Register Associated with Interrupt Generation by External Interrupt Circuit 1 and Vector Table Table 10.5-1 Register Associated with Interrupt Generation by External Interrupt Circuit 1 and Vector Table | Interrupt designation | Interrupt le | Vector table address | | | | |-----------------------|---------------------------------------|----------------------|-------------|-------------------|-------------------| | interrupt designation | Interrupt designation Register Bit fo | | tting level | Upper | Lower | | IRQ0 | | L01 (bit1) | L00 (bit0) | FFFA <sub>H</sub> | FFFB <sub>H</sub> | | IRQ1 | ILR1 (007B <sub>H</sub> ) | L11 (bit3) | L10 (bit2) | FFF8 <sub>H</sub> | FFF9 <sub>H</sub> | | IRQ2 | | L21 (bit5) | L20 (bit4) | FFF6 <sub>H</sub> | FFF7 <sub>H</sub> | For interrupt operation, see Section "3.4.2 Steps in the Interrupt Operation ". #### **■** Exercise Caution when Changing Edge Polarity Selection When changing edge polarity for INT10 to INT12, always write "0" for the appropriate EIR bit to prevent unintended interrupt generation. # 10.6 Operations of External Interrupt Circuit 1 The external interrupt circuit 1 can detect a specified edge or edges of a signal input to any of the external interrupt pins. #### ■ Operation of External Interrupt Circuit 1 To operate external interrupt circuit 1, the bits of the registers must be set as shown in Figure 10.6-1. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 EIC1 EIR1 SL11 SL10 EIE1 EIR0 SL01 SL00 EIE0 0 0 0 0 0 0 0 $\bigcirc$ EIR2 SL21 SL20 EIC2 EIE2 0 0 0 0 DDR3 0 0 0 X X X X TCR2 PEN TSEL 0 $\times$ : Used bit 0 $\times$ : Unused bit 0 : Set "0" Figure 10.6-1 Setting External Interrupt Circuit 1 When the polarity of an edge or edges of a signal input from one of the external interrupt pins 1 (INT10 to INT12) matches the selected edge polarity for the pin stored in the appropriate external interrupt control register (EIC1, EIC2:SL00 to SL21), one of the external interrupt request flag bits (EIC1, EIC2:EIR0 to EIR2) corresponding to the pin is set to "1". Figure 10.6-2 shows the operation when an external interrupt is input to the INT10 pin. Figure 10.6-2 Operation of External Interrupt 1 (INT10) #### Note: Even when the pin is used as an external interrupt input pin, the pin state can be read directly from the port data register (PDR3). # 10.7 Program Example for External Interrupt Circuit 1 #### An example of programming external interrupt circuit 1 is given below. #### **■** External Interrupt Circuit 1 Programming Example **XCHW** A,T #### Processing specification External interrupt circuit 1 detects the rising edge of a pulse input to the INT10 pin and generates an interrupt. #### Coding example | , 1 - | | | | | |-------|-------|--------------------------|-----|---------------------------------------------------------| | DDR3 | EQU | 000DH | ; | Address of port data direction register (DDR) | | EIC1 | EQU | 0024H | ; | External interrupt control register 1 | | TCR2 | EQU | 0020H | ; | Address of 8/16-bit capture timer output control | | | | | | register | | ILR1 | EQU | 007BH | ; | Setting of interrupt level setting register 1 | | | | | | | | EIR0 | EQU | EIC1:3 | ; | Definition of external interrupt request flag bit | | SL01 | EQU | EIC1:2 | ; | Definition of edge polarity selection bits | | SL00 | EQU | EIC1:1 | ; | Definition of edge polarity selection bits | | EIE0 | EQU | EIC1:0 | ; | Definition of interrupt request enable bit | | INT_V | DSEG | ABS | ; | [DATA SEGMENT] | | | ORG | 0FFFAH | | | | IRQ1 | DW | WARI | ; | Interrupt vector (INT1) setting | | INT_V | ENDS | | | | | ; | l | Main program | | | | | CSEG | | ; | [CODE SEGMENT] | | | | | ; | Stack pointer (SP) is assumed to have been initialized. | | | : | | ; | | | | CLRI | | ; | Disable interrupts. | | | CLRB | EIR1 | ; | Clear external interrupt request flag. | | | MOV | TCR2,#00000000B | ; | Set pin P34/TO/INT10 to serve port inputs. | | | MOV | DDR3,#00000000B | ; | Set P34 to serve inputs only. | | | MOV | ILR1,#11111110B | ; | Set interrupt level at 2. | | | CLRB | SL01 | ; | Select rising edge. | | | SETB | SL00 | ; | | | | CLRB | EIR0 | ; | Clear external interrupt request flag. | | | SETB | EIE0 | ; | Enable interrupt request outputs. | | | SETI | | ; | Enable interrupts. | | | : | | | | | ; | I | Interrupt processing rou | tin | g | | WARI | CLRB | EIE0 | ; | Clear external interrupt request flag (INT0). | | | PUSHW | A | | | | | | | | | ## CHAPTER 10 EXTERNAL INTERRUPT CIRCUIT 1 (EDGE) | | PUSHW | A | |---|-------------|--------| | | : | | | | User proce | essing | | | : | | | | POPW | A | | | XCHW | A,T | | | POPW | A | | | RETI | | | | <b>ENDS</b> | | | ; | | | | | END | | # CHAPTER 11 # EXTERNAL INTERRUPT CIRCUIT 2 (LEVEL) This chapter describes the function and operation of an external interrupt circuit 2 (level). - 11.1 Overview of External Interrupt Circuit 2 - 11.2 Configuration of External Interrupt Circuit 2 - 11.3 Pins of External Interrupt Circuit 2 - 11.4 Registers of External Interrupt Circuit 2 - 11.5 Interrupt of External Interrupt Circuit 2 - 11.6 Operations of External Interrupt Circuit 2 - 11.7 Program Example for External Interrupt Circuit 2 ## 11.1 Overview of External Interrupt Circuit 2 External interrupt circuit 2 detects the predetermined level of a signal input to any of the eight external interrupt pins and generates and issues an interrupt request to the CPU. #### ■ Functions of External Interrupt Circuit 2 (Level Detection) External interrupt circuit 2 functions to detect an "L" level signal input to any of the external interrupt pins and generate and issue an interrupt request to the CPU, thereby enabling recovery from standby mode and a transition to normal operating state (main clock operation mode). - External interrupt pins: Eight pins (P00/INT20/AN4 to P03/INT23/AN7, P04/INT24 to P07/INT27) - External interrupt triggering: Input of an "L" level signal to one of the above external interrupt pins triggers an external interrupt. - Interrupt control: An external interrupt 2 control register (EIE2) enables or disables external interrupt inputs. - Interrupt flag: Detection of the "L" level is indicated by an external interrupt request flag bit of the external interrupt 2 flag register (EIF2). - Interrupt request: An interrupt request is generated if the state of one of the above external interrupt pins is "L" (IRQA). # 11.2 Configuration of External Interrupt Circuit 2 The external interrupt circuit 2 comprises the following three blocks: - Interrupt request generating circuit - External interrupt 2 control register (EIE2) - External interrupt 2 flag register (EIF2) #### ■ Block Diagram of External Interrupt Circuit 2 Figure 11.2-1 Block Diagram of External Interrupt Circuit 2 #### Interrupt request generating circuit The interrupt request generating circuit generates an interrupt request signal in accordance with the signal input to one of the external interrupt pins ( $\overline{\text{INT20}}$ to $\overline{\text{INT27}}$ ) and the contents of an external interrupt input enable bit. #### External interrupt 2 control register (EIE2) The external interrupt input enable bits (IE20 to IE27) enable or disable "L" level input from the external interrupt pins, with each bit corresponding to a pin. #### External interrupt 2 flag register (EIF2) The external interrupt request flag bit (IF20) is used to hold or clear an interrupt request signal. #### Trigger causing external interrupt circuit 2 to generate an interrupt • IRQA: When an "L" level signal is input to any of the external interrupt pins INT20 to INT27 and the external interrupt input enable bit corresponding to the pin is "1", external interrupt circuit 2 generates an interrupt request. ## 11.3 Pins of External Interrupt Circuit 2 This section describes the pins associated with external interrupt circuit 2 and illustrates a block diagram of circuitry terminating at the pins with reference to the registers and interrupt triggering. #### ■ Pins Associated with External Interrupt Circuit 2 The pins associated with external interrupt circuit 2 are eight external interrupt pins. #### P00/INT20/AN4 to P03/INT23/AN7 These external interrupt pins function as external interrupt input pins (hysteresis input) and as the pins of the general-purpose I/O port and analog inputs. The P00/INT20/AN4 to P03/INT23/AN7 pins function as external interrupt input pins (INT20 to INT23) if set to function as an input port by the corresponding bits of the port 0 data direction register (DDR0), if set to be enabled for external interrupt inputs (ADEN=0) by the corresponding bits of the A/D enable register (ADEN), and if external interrupt inputs are enabled (EIE2:IE20 to IE27=1) by the external interrupt 2 control register (EIE2). When set to function as an input port by the DDR0 register, the state of these pins can be read from the port 0 data register (PDR0) at any time. #### ● P04/INT24 to P07/INT27 These external interrupt pins function as external interrupt input pins (hysteresis input) and also serving as the pins of the general-purpose I/O port. The $P04/\overline{INT24}$ to $P07/\overline{INT27}$ pins function as external interrupt input pins ( $\overline{INT24}$ to $\overline{INT27}$ ) if set to function as an input port by the corresponding bits of the port 0 data direction register (DDR0) and if external interrupt inputs are enabled by the external interrupt 2 control register (EIE2). When set to function as an input port, the state of these pins can be read from the port 0 data register (PDR0) at any time. Table 11.3-1 lists the pins associated with external interrupt circuit 2. Table 11.3-1 Pins Associated with External Interrupt Circuit 2 | External interrupt pin | Use for external interrupt input (Interrupt input enabled) | Use for general-purpose I/O port (Interrupt input disabled) | |----------------------------------------------------------|------------------------------------------------------------|-------------------------------------------------------------| | P00/INT20/AN4 | TNT20 (EIE2:IE20=1,DDR0:bit0=0,ADEN:ADE4=0) | P00 (EIE2:IE20=0) | | P01/INT21/AN5 | TNT21 (EIE2:IE21=1,DDR0:bit1=0,ADEN:ADE5=0) | P01 (EIE2:IE21=0) | | P02/INT22/AN6 | TNT22 (EIE2:IE22=1,DDR0:bit2=0,ADEN:ADE6=0) | P02 (EIE2:IE22=0) | | P03/INT23/AN7 | ĪNT23 (EIE2:IE23=1,DDR0:bit3=0,ADEN:ADE7=0) | P03 (EIE2:IE23=0) | | P04/INT24 | | P04 (EIE2:IE24=0) | | P05/ <u>INT25</u> <u>INT25</u> (EIE2:IE25=1,DDR0:bit5=0) | | P05 (EIE2:IE25=0) | | P06/INT26 | | P06 (EIE2:IE26=0) | | P07/INT27 | <u>INT27</u> (EIE2:IE27=1,DDR0:bit7=0) | P07 (EIE2:IE27=0) | # ■ Block Diagram of Circuitry Terminating at the Pins Associated with External Interrupt Circuit 2 Figure 11.3-1 Block Diagram of Circuitry Terminating at the Pins Associated with External Interrupt Circuit 2 #### Note: When the ON setting of the pull-up resistor is selected by the pull-up setting register, the pin state will be "H" level (pull-up state) rather than Hi-Z during stop mode (SPL = 1). During a reset, however, the pull-up is invalid and the pin remains at Hi-Z. # ■ Association between the Interrupt Enable Bits for External Interrupt Circuit 2 and the External Interrupt Pins The interrupt enable bits are associated with the external interrupt pins as listed in Table 11.3-2. Table 11.3-2 Correspondence between the External Interrupt Enable Bits and the External Interrupt Pins | Register | Bit r | External interrupt pin | | |----------|-------|------------------------|-------| | | bit7 | IE27 | ĪNT27 | | | bit6 | IE26 | ĪNT26 | | | bit5 | IE25 | ĪNT25 | | EIE2 | bit4 | IE24 | ĪNT24 | | EIE2 | bit3 | IE23 | ĪNT23 | | | bit2 | IE22 | ĪNT22 | | | bit1 | IE21 | ĪNT21 | | | bit0 | IE20 | ĪNT20 | # 11.4 Registers of External Interrupt Circuit 2 The external interrupt 2 control register (EIE2) is used to enable or disable the external interrupt pins. #### ■ Registers Associated with External Interrupt Circuit 2 Figure 11.4-1 Registers Associated with External Interrupt Circuit 2 # 11.4.1 External Interrupt 2 Control Register (EIE2) The external interrupt circuit 2 control register (EIE2) enables or disables the interrupt inputs to the external interrupt pins INT20 to INT27. #### ■ External Interrupt Circuit 2 Control Register (EIE2) Figure 11.4-2 External Interrupt Circuit 2 Control Register (EIE2) Table 11.4-1 Correspondence between the Bits of the External Interrupt 2 Control Register (EIE2) and the External Interrupt Pins | Register | Bit ı | name | External interrupt pin | |----------|-------|------|------------------------| | | bit7 | IE27 | ĪNT27 | | | bit6 | IE26 | ĪNT26 | | | bit5 | IE25 | ĪNT25 | | EIE2 | bit4 | IE24 | ĪNT24 | | EIE2 | bit3 | IE23 | ĪNT23 | | | bit2 | IE22 | ĪNT22 | | | bit1 | IE21 | ĪNT21 | | | bit0 | IE20 | ĪNT20 | Table 11.4-2 Functions of the Bits of the External Interrupt 2 Control Register (EIE2) | | Bit name | Function | |--------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7<br>to<br>bit0 | IE27 to IE20:<br>External interrupt<br>input enable bits | <ul> <li>These bits enable or disable the interrupt inputs to external interrupt pins INT20 to INT27.</li> <li>When one of these bits is set to "1", the corresponding external interrupt pin functions as an external interrupt input pin and accepts external interrupt inputs.</li> <li>When the bit is set to "0", the corresponding pin functions as a general-purpose port, but does not accept external interrupt inputs.</li> <li>Notes: <ul> <li>When using a pin as an external interrupt pin, write "0" in the port 0 data direction register (DDR0) in the bit corresponding to the pin so that the pin serves inputs only.</li> <li>Regardless of the external interrupt input enable bit state, the state of the external interrupt pin can be read directly from the port 0 data register (PDR0). For pins INT20 to INT23, furthermore, write "0" into A/D enable register (ADEN) in the bits corresponding to the pins to use the pins for external interrupt inputs.</li> </ul> </li> </ul> | # 11.4.2 External Interrupt 2 Flag Register (EIF2) The external interrupt 2 flag register (EIF2) is used to hold the interrupt state by flagging an interrupt request flag when a level interrupt is detected and then clearing the flag. #### **■** External Interrupt 2 Flag Register (EIF2) Figure 11.4-3 External Interrupt 2 Flag Register (EIF2) Table 11.4-3 Explanation of Functions of Each Bit in External Interrupt 2 Flag Register (EIF2) | Bit name | | Function | |--------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7<br>to<br>bit1 | Unused bits | <ul><li>Bit value is undefined when being read.</li><li>The written value does not affect other operations.</li></ul> | | bit0 | IF20:<br>External interrupt<br>request flag bit | When an "L" level signal is input to one of the external interrupt pins(\overline{INT20}\) to \overline{INT27}\) for which external interrupt inputs are enabled, this bit is set to "1". Writing "0" clears this bit, and writing "1" does not change this bit state and does not affect other operations. Note: The external interrupt enable bits of the external interrupt 2 control register (EIE2:IE20 to IE27) may disable external interrupt inputs. Interrupt requests continue to be generated and issued to the CPU until the IF20 bit is cleared to "0". | ## 11.5 Interrupt of External Interrupt Circuit 2 # An "L" level input signal input to one of the external interrupt pins triggers external interrupt circuit 2 to generate an interrupt. #### ■ Interrupt during the Operation of External Interrupt Circuit 2 When an "L" level signal is input to one of the external interrupt pins for which interrupt inputs are enabled, the external interrupt request flag bit (EIF2:IF20) is set to "1" and external interrupt circuit 2 generates and issues an interrupt request (IRQA) to the CPU. Write "0" for the IF20 bit within the interrupt processing routine, thus clearing the interrupt request. When the external interrupt request flag bit (IF20) is set to "1", external interrupt circuit 2 generates the interrupt request, even if external interrupt inputs to the pin are set to disabled by the bit corresponding to the pin among the interrupt enable bits (IE20 to IE27) of the external interrupt 2 control register (EIE2), until the IF20 bit is cleared. Therefore, the IF20 bit must always be cleared. If the "L" level input to the external interrupt pin continues as it is, even if the IF20 bit is cleared with external interrupt inputs to the pin remaining enabled, the IF20 bit is immediately set to "1" again. Disable external interrupt inputs to the pin or remove the cause of the external interrupt as required. #### Notes: - When enabling interrupts to the CPU following a release from the reset state, clear the IF20 bit in advance. - "L" level inputs to external interrupt pins (INT20 to INT27) trigger external interrupt circuit 2 to generate the same interrupt request (IRQA). Thus, when an external interrupt input is detected, it is necessary to identify the pin at which the input occurs by reading the port 0 data register (PDR0) before the input changes to "H" level. Only external interrupt circuits 1 and 2 can execute a release from the stop mode by an interrupt. # ■ Register Associated with Interrupt Generation by External Interrupt Circuit 2 and Vector Table Table 11.5-1 Register Associated with Interrupt Generation by External Interrupt Circuit 2 and Vector Table | Interrupt designation | Interrupt | level setting reg | ister | Vector table address | | | |-----------------------|---------------------------|-----------------------|------------|----------------------|-------------------|--| | interrupt designation | Register | Bit for setting level | | Upper | Lower | | | IRQA | ILR3 (007D <sub>H</sub> ) | LA1 (bit5) | LA0 (bit4) | FFE6 <sub>H</sub> | FFE7 <sub>H</sub> | | For interrupt operation, see Section "3.4.2 Steps in the Interrupt Operation ". # 11.6 Operations of External Interrupt Circuit 2 External interrupt circuit 2 detects "L" level at any of the external interrupt pins, then generates and issues an interrupt request to the CPU. #### ■ Operation of External Interrupt Circuit 2 To operate the external interrupt circuit 2, the bits of the registers must be set as shown in Figure 11.6-1. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 EIE2 IE27 IE26 IE25 IE24 IE23 IE22 IE21 IE20 0 0 0 $\odot$ 0 $\odot$ $\odot$ $\odot$ EIF2 IF20 0 DDR0 0 0 0 0 0 0 0 **ADEN** 0 0 0 : Used bit $\times$ : Unused bit : Set "0" Figure 11.6-1 Setting External Interrupt Circuit 2 When an "L" level signal is input to an external interrupt pin among the pins $\overline{\text{INT20}}$ to $\overline{\text{INT27}}$ with external interrupt inputs being enabled by one of the IE20 to IE27 bits corresponding to the pin, external interrupt circuit 2 generates and issues an IRQA interrupt request to the CPU. Figure 11.6-2 shows the operation of external interrupt circuit 2 (when the <u>INT20</u>/AN4 pin is used). Figure 11.6-2 Operation of External Interrupt 2 (INT20) #### Note: Even when the pin is used as an external interrupt input pin, the pin state can be read directly from the port 0 data register (PDR0). # 11.7 Program Example for External Interrupt Circuit 2 #### An example of programming external interrupt circuit 2 is given below. #### ■ Program Example for External Interrupt Circuit 2 #### Processing specification The external interrupt circuit 2 detects an "L" level signal input to the $P00/\overline{INT20}/AN4$ pin and generates an interrupt. #### Coding example | DDR0<br>ADEN<br>EIE2<br>EIF2 | EQU<br>EQU<br>EQU | 0001H<br>0034H<br>0036H<br>0037H | ; | Address of the port data direction register Address of the A/D enable register Address of the external interrupt 2 control register Address of the external interrupt 2 flag register | |------------------------------|-------------------|----------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IF20 | EQU | EIF2:0 | ; | Definition of the external interrupt request flag bit | | ILR3 | EQU | 007DH | ; | Address of the interrupt level setting register | | INT_V | ORG | ABS<br>0FFE6H | ; | [DATA SEGMENT] | | IRQA<br>INT_V | DW<br>ENDS | WARI | ; | Interrupt vector setting | | | | Main program | | | | CSEG | | | ; | [CODE SEGMENT] Stack pointer (SP) is assumed to have been initialized. | | | : | | , | Stack pointer (SF) is assumed to have been initialized. | | CLRI | • | | • | Disable interrupts. | | CLRB | IF20 | | : | Clear external interrupt request flag. | | MOV | ILR2,#11 | 111110B | ; | Set interrupt level to 2. | | MOV | DDR0,#00 | 0000000В | ; | Set pin INT20/AN4 to serve inputs only. | | MOV | ADEN,#0 | 0000000B | ; | Set pin $\overline{INT20}/AN4$ to enable external interrupt inputs. | | MOV<br>SETI | EIE2,#000 | 000001B | ; | Enable external interrupt inputs to pin $\overline{INT20}/AN4$ . Enable interrupts. | | ; | | Interrupt processing r | outi | ne | | WARI | MOV<br>CLRB | EIE2,#00000000B<br>IF20 | ; | Disable external interrupt inputs to pin $\overline{INT20}/AN4$ . Clear external interrupt request flag. | #### CHAPTER 11 EXTERNAL INTERRUPT CIRCUIT 2 (LEVEL) ## CHAPTER 11 EXTERNAL INTERRUPT CIRCUIT 2 (LEVEL) # **CHAPTER 12** # A/D CONVERTER This chapter describes the functions and operations of the A/D converter. - 12.1 Overview of A/D Converter - 12.2 Configuration of A/D Converter - 12.3 Pins of A/D Converter - 12.4 Registers of A/D Converter - 12.5 Interrupt of A/D Converter - 12.6 Operations of A/D Converter Functions - 12.7 Notes on Using A/D Converter - 12.8 Program Example for A/D Converter #### 12.1 Overview of A/D Converter An A/D converter, which is of a 10-bit successive approximation type, selects an input signal from eight channel analog inputs. The A/D converter can be activated with software, an internal clock, or the output of an 8/16-bit capture timer/counter (16-bit mode). #### ■ A/D Conversion Functions These functions convert the analog voltage (input voltage) input from an analog input to 10-bit digital values. - An analog input can be selected from eight channels. - The conversion speed is 38 instruction cycles (when the main clock oscillation frequency is 12.5 MHz, the speed is $12.2 \,\mu s$ ). - When A/D conversion is completed, an interrupt occurs. - Software can determine that the conversion has been completed. To activate A/D conversion functions, follow one of the methods given below. - Activation with a software program. - Continuous activation through the output of a time-base timer (main clock oscillation frequency divided by 2<sup>8</sup>). - Continuous activation through the output of an 8/16-bit capture timer/counter (16-bit mode). # 12.2 Configuration of A/D Converter The A/D converter consists of the following nine blocks. - Clock selector (input clock selector for activation of A/D conversion) - Analog channel selector - Sample hold circuit - D/A converter - Comparator - Control circuit - A/D data register (ADDH and ADDL) - A/D control register 1 (ADC1) - A/D control register 2 (ADC2) #### ■ Block Diagram of the A/D Converter Figure 12.2-1 Block Diagram of the A/D Converter #### Clock selector The clock selector selects the clock to be used to activate A/D conversion while continuous activation is enabled (ADC2: EXT = 1). #### Analog channel selector This circuit selects one out of the eight analog inputs. #### Sample hold circuit This circuit holds the input voltage selected by the analog channel selector. By performing the sample hold of the voltage input immediately after the activation of A/D conversion, A/D conversion can be performed without the variance of the input voltage affecting it during A/D conversion (during comparison). #### D/A converter This generates the voltage that corresponds to the values set in the ADDH and ADDL registers. #### Comparator This compares the input voltage for which sample hold is performed, with the output voltage of the D/A converter to determine which is the greater of the two. #### Control circuit The control circuit has the following function. • For A/D conversion functions, this circuit determines the values in turn from the MSB in the 10-bit A/D data register toward the LSB based on the large and small signals from the comparator. When the conversion is completed, it sets the interrupt request flag bit (ADC1: ADI). #### A/D data register (ADDH and ADDL) The high-order 2 bits of 10-bit A/D data are stored in the ADDH register. The low-order 8 bits of 10-bit A/D data are stored in the ADDL register. The ADDH and ADDL registers have the following function. • For A/D conversion function, these registers store the results of A/D conversion. #### A/D control register 1 (ADC1) This register is used to enable and disable functions, select an analog input, check statuses, and control interrupts. #### A/D control register 2 (ADC2) This register is used to select an input clock, enable and disable interrupts, select functions, and perform other activities. #### Interrupts of the A/D converter When the set conditions are satisfied at the completion of A/D conversion for IRQ8, if an interrupt request output is enabled (ADC2: ADIE = 1), an interrupt request occurs. #### 12.3 Pins of A/D Converter This section describes the pins related to the A/D converter and shows a block diagram of the pins related to the A/D converter. #### ■ Pins Related to the A/D Converter The pins related to the A/D converter are P03/INT23/AN7 to P00/INT20/AN4, and P43/AN3 to P40/AN0 pins. #### P03/INT23/AN7 to P00/INT20/AN4 and P43/AN3 to P40/AN0 P03/INT23/AN7 to P00/INT20/AN4, and P43/AN3 to P40/AN0 pins can be used as general-purpose I/O ports (P03 to P00, and P43 to P40) and as analog inputs (AN7 to AN0). #### [AN7 to AN0] When A/D conversion functions are used, input the analog voltage to be converted to these pins. To enable a pin as the analog input, set "1" to the bit that corresponds to the A/D enable register (ADEN), set "0" to the bit that corresponds to the port data direction register (DDR0), and switch the output transistor to OFF, and select one using the bit for selecting an analog input channel (ADC1: ANS0 to ANS2). Even when the A/D converter is used, pins not used as analog inputs can be used as general-purpose I/O ports. #### ■ Block Diagram of the Pins Related to the A/D Converter Figure 12.3-1 Block Diagram of P03/INT23/AN7 to P00/INT20/AN4 Pins Figure 12.3-2 Block Diagram of P43/AN3 to P40/AN0 Pins # 12.4 Registers of A/D Converter #### Figure 12.4-1 shows the registers related to the A/D converter. #### ■ Registers Related to the A/D Converter Figure 12.4-1 Registers Related to the A/D Converter ## 12.4.1 A/D Control Register 1 (ADC1) A/D control register 1 (ADC1) is used to set the enabling and disabling functions of the A/D converter, select an analog input, and check the status. #### ■ A/D Control Register 1 (ADC1) Figure 12.4-2 A/D Control Register 1 (ADC1) Table 12.4-1 Explanation of Functions of Each Bit in the Bits in A/D Control Register 1 (ADC1) | | Bit name | Function | |--------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | Unused bit | <ul> <li>The value during read is not determined.</li> <li>Write does not affect operations.</li> </ul> | | bit6<br>to<br>bit4 | ANS2, ANS1, ANS0:<br>Analog input channel<br>selection bits | This bit is used to select which pin to be used as an analog input from AN0 to AN7. When software is activated (ADC2: EXT = 0), this bit can be rewritten concurrently with the activation of A/D conversion (AD = 1). Note: Pins not used as analog inputs can be used as general-purpose ports. | | bit3 | ADI:<br>Interrupt request flag<br>bit | <ul> <li>When A/D conversion functions are enabled:</li> <li>When A/D conversion is completed, "1" is set to this bit.</li> <li>When this bit and the bit for enabling an interrupt request (ADC2: ADIE) are "1", an interrupt request is output.</li> <li>At write, this bit is cleared with "0". When "1" is set to this bit, nothing is changed or affected by this.</li> </ul> | | bit2 | ADMV:<br>Convertion flag bit | This bit indicates that A/D conversion is being performed, when A/D conversion functions are enabled. During conversion (comparison), this bit is set to "1". Note: This bit is read-only. The written value is ignored and nothing is affected by the value. | | bit1 | RESV0:<br>Reserved bit | <ul> <li>The value during read is not determined.</li> <li>Write does not affect operations.</li> </ul> | | bit0 | AD:<br>A/D conversion<br>activation bit | <ul> <li>This bit is used to activate A/D conversion functions with software.</li> <li>In the state where continuous activation is not performed (ADC2: EXT = 0), when "1" is set to this bit, A/D conversion functions are activated.</li> <li>Notes:</li> <li>Even if "0" is written to this bit, the operation of A/D conversion functions cannot be stopped. The read value is always "0".</li> <li>During continuous activation, this bit is ignored.</li> </ul> | ## 12.4.2 A/D Control Register 2 (ADC2) A/D control register 2 (ADC2) is used to select an input clock, enable and disable an interrupt and continuous activation. #### ■ A/D Control Register 2 (ADC2) Figure 12.4-3 A/D Control Register 2 (ADC2) Table 12.4-2 Explanation of Functions of Each Bit in A/D Control Register 2 (ADC2) | | Bit name | Function | |---------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | Unused bit | <ul><li>The value during read is not determined.</li><li>Write does not affect operations.</li></ul> | | bit6,<br>bit5 | RESV4,RESV3:<br>Reserved bits | <ul> <li>This bit is a reserved bit.</li> <li>Be sure to write 00<sub>B</sub> to these bits.</li> </ul> | | bit4 | ADCK:<br>Selecting an input<br>clock bit | This bit is used to select an input clock for activation of A/D conversion functions in the state where continuous activation is performed (EXT = 1). When this bit is "0", the internal clock with an oscillation frequency (selected using the output of a time-base timer) divided by $2^8$ is selected. When "1", the output of an 8/16-bit capture timer/counter (TO: 16-bit mode) is selected. | | bit3 | ADIE:<br>Enabling an interrupt<br>request bit | This bit is used to enable and disable the output of an interrupt to the CPU. When this bit and the interrupt request flag bit (ADC1: ADI) are "1", an interrupt request is output. | | bit2 | RESV2:<br>Reserved bit | <ul><li>This bit is a reserved bit.</li><li>Be sure to write "0" to this bit.</li></ul> | | bit1 | EXT: Bit for enabling continuous activation | This bit is used to select whether the A/D conversion functions are to be activated with software or activated continuously in synchronization with an input clock. When this bit is "0", software activation with the bit for activating A/D conversion (ADC1: AD) is enabled. When "1", continuous activation on the rising edge of the clock selected using the bit for selecting an input clock (ADC2: ADCK) is enabled. | | bit0 | RESV1:<br>Reserved bit | <ul><li>This bit is a reserved bit.</li><li>Be sure to write "1" to this bit.</li></ul> | #### 12.4.3 A/D Data Register (ADDH and ADDL) A/D data register (ADDH and ADDL) stores the results of A/D conversion at 10-bit A/D conversion. The high-order 2 bits of 10-bit data correspond to the ADDH register. The low-order 8 bits correspond to the ADDL register. #### ■ A/D Data Register (ADDH and ADDL) Figure 12.4-4 shows the bit configuration of the A/D data registers. Figure 12.4-4 A/D Data Registers (ADDH and ADDL) ADDH (A/D data register H) Initial value Address bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 0032<sub>H</sub> ----XX<sub>B</sub> R ADDL (A/D data register L) Address bit7 bit6 bit5 bit4 bit3 bit0 Initial value bit2 bit1 $0033_{H}$ XXXXXXXX<sub>B</sub> R R R R R R Read only R Χ Undefined Of the 10-bit A/D data, the high-order 2 bits correspond to bits 1 and 0 in the ADDH register. The loworder 8 bits correspond to bits 7 to 0 in the ADDL register. #### When A/D conversion functions are enabled When A/D conversion is activated, after about 38 instruction cycles, the data on the conversion results are fixed and stored to these registers. Therefore, after A/D conversion, read these registers (conversion results), write "0" to the ADI bit (bit3) in the ADC1 register until the next A/D conversion is completed, and clear the flags after A/D conversion. During A/D conversion, the values in these registers are not determined. When A/D conversion functions are enabled, these registers function as read-only registers. # 12.4.4 A/D Enable Register (ADEN) The ADEN register is used to select the analog input port that corresponds to different pins. Writing "1" to an appropriate ADEN register bit enables analog input. #### ■ A/D Enable Register (ADEN) Figure 12.4-5 shows the bit configuration of the A/D enable register. Address bit2 bit7 bit6 bit5 bit4 bit3 bit1 bit0 Initial value 0034H ADE7 ADE6 ADE5 ADE4 ADE3 ADE2 ADE1 ADE0 0000000B R/W R/W R/W R/W R/W R/W R/W R/W ADE7 to ADE0 A/D input bits 0 Port input 1 Analog input R/W: Readable/Writable : Initial value Figure 12.4-5 A/D Enable Register (ADEN) An A/D input port can be used as a general-purpose I/O port. The ADEN register is used to select the port that corresponds to the analog input. Set "1" to the corresponding bit in the ADEN register for the port to be used for analog input. This prevents the DC pass when the middle level voltage is applied to the A/D input port. When this register is to be used as the A/D input port, do not select the bit that indicates use of a pull-up resistor from the pull-up setting register. ## 12.5 Interrupt of A/D Converter #### A factor for an interrupt of the A/D converter is the following. Completion of conversion when A/D conversion functions are enabled #### ■ Interrupt when A/D Conversion Functions are Enabled When A/D conversion is completed, the interrupt request flag bit (ADC1: ADI) is set to "1". At this time, if the bit for enabling an interrupt request is enabled (ADC2: ADIE = 1), an interrupt request to the CPU (IRQ8) occurs. Write "0" to the ADI bit using the routine for interrupt handling to clear the interrupt request. The ADI bit is set when A/D conversion is completed, irrespective of the value of the ADIE bit. #### Note When the ADI bit is "1", if the ADIE bit is enabled (changed from "0" to "1"), an interrupt request occurs immediately. #### ■ Register and Vector Table Related to the Interrupt of the A/D Converter Table 12.5-1 Register and Vector Table Related to the Interrupt of the A/D Converter | Interrupt name | Register to set the interrupt level | | | Address of the vector table | | |----------------|-------------------------------------|---------------|------------|-----------------------------|-------------------| | | Register | Bit to be set | | High order | Low order | | IRQ8 | ILR3 (007D <sub>H</sub> ) | L81 (bit1) | L80 (bit0) | FFEA <sub>H</sub> | FFEB <sub>H</sub> | See Section "3.4.2 Steps in the Interrupt Operation " for the interrupt operation. # 12.6 Operations of A/D Converter Functions ### The A/D converter can be activated with software or activated continuously. ## ■ Activating the A/D Converter Functions #### Software activation To activate A/D conversion functions with software, set registers as shown in Figure 12.6-1 . Figure 12.6-1 Setting A/D Conversion Functions (at Software Activation) When A/D conversion is activated, the operations of A/D conversion functions are started. In addition, even during conversion, A/D conversion functions can be reactivated. #### Continuous activation To activate A/D conversion functions continuously, set registers as shown in Figure 12.6-2. Figure 12.6-2 Setting A/D Conversion Functions (at Continuous Activation) When continuous activation is enabled, A/D conversion is activated on a rising edge of the selected input clock and the operations of A/D conversion functions are started. When continuous activation is disabled (ADC2: EXT = 0), continuous activation is stopped and activation with software is possible. ### Operations of A/D Conversion Functions The operations of the A/D converter are described here. It takes about 38 instruction cycles from activating A/D conversion to completing it. - 1. When A/D conversion is activated, the conversion in-progress flag bit is set (ADC1: ADMV = 1), and the analog input set is connected to the sample hold circuit. - 2. During about 16 instruction cycles, the voltage of the analog input is captured and held in the capacitor for internal sample hold. This voltage is held until A/D conversion has been completed. - The comparator compares the voltage captured and held in the capacitor for sample hold with the reference voltage for A/D conversion from the MSB to the LSB. The results are transferred to the ADDH and ADDL registers in turn. - 4. When all the results have been transferred to the ADDH and ADDL registers, the conversion inprogress flag bit is cleared (ADC1: ADMV = 0), and the interrupt request flag bit is set (ADC1: ADI = 1). # 12.7 Notes on Using A/D Converter This section describes notes on using the A/D converter. ### ■ Notes on Using the A/D Converter #### Input impedance of the analog input The A/D converter contains the sample hold circuit as shown in Figure 12.7-1 , captures the voltage of the analog input, and holds it in the capacitor for sample hold in about 16 instruction cycles, after activation of A/D conversion. Accordingly, when the output impedance of the external circuit of the analog input is high, the analog input voltage may not be stabilized during analog input sampling period. Therefore, set the output impedance of the external circuit to a sufficiently low level (lower than about 4 k $\Omega$ ). If the output impedance of the external circuit cannot be set low, it is recommended that a capacitor with about 0.1 $\mu$ F be added externally to the analog input. MB89202/F202RA series Sample hold circuit AN0 to AN7 Selecting an analog channel After activation of A/D conversion, close 16 instruction cycles Figure 12.7-1 Equivalent Circuit of Analog Input #### Notes on setting using a program - When A/D conversion functions are enabled, the values in the ADDH and ADDL registers are held without being changed until the activation of A/D conversion. However, once A/D conversion is activated, the values in the ADDH and ADDL registers become undefined immediately. - When A/D conversion functions are enabled, do not reselect an analog input channel (ADC1: ANS3 to ANS0). Especially, during continuous activation, disable continuous activation (ADC2: EXT = 0), and wait for the conversion in-progress flag bit (ADC1: ADMV) to be "0" for reselection. - The A/D converter is stopped via a reset and activation of the stop mode, and all registers are initialized. - When the interrupt request flag bit (ADC1: ADI) is "1" and an interrupt request is enabled (ADC2: ADIE = 1), recovery from interrupt handling is no longer possible. Be sure to clear the ADI bit. #### Note: When A/D conversion is completed, if the next conversion is reactivated, the interrupt request flag bit (ADC1: ADI) is not set. #### CHAPTER 12 A/D CONVERTER #### Notes on interrupt requests If A/D conversion is reactivated (ADC1: AD = 1) and terminated at the same time, the interrupt request flag bit (ADC1: ADI) is not set. #### Conversion time Changing the oscillation frequency or clock speed (gear functions) affects the conversion speed of A/D conversion functions. #### Input clock of continuous activation The output of an 8/16-bit capture timer/counter is affected by gear functions. The output of a time-base timer is not affected by gear functions. Clearing a time-base timer affects cycles. Since the output of an 8/16-bit capture timer/counter is the output of the 16-bit mode, the 8-bit mode cannot be used. # 12.8 Program Example for A/D Converter # This section shows a program example of the 10-bit A/D converter. # ■ Program Example of the A/D Conversion Functions ### Processing specifications The analog voltage to be applied to the AN0 pin is converted to digital voltage through software activation. In this example, completion of conversion is detected in a loop in the program without using interrupts. ### Coding example | PDR4 | EQU | 000FH | ; | Address of port 4 data register 4 | |------|-------|-----------------|---|---------------------------------------------------------| | ADC1 | EQU | 0030H | ; | Address of A/D control register 1 | | ADC2 | EQU | 0031H | ; | Address of A/D control register 2 | | ADDH | EQU | 0032H | ; | Address of A/D data register H | | ADDL | EQU | 0033H | ; | Address of A/D data register L | | ADEN | EQU | 0034H | ; | Enables the A/D input pin. | | AN0 | EQU | PDR4:0 | ; | Defines the AN0 analog input. | | ADE0 | EQU | ADEN:0 | ; | Enables the AN0 analog input. | | ADI | EQU | ADC1:3 | ; | Defines the interrupt request flag bit. | | ADMV | ' EQU | ADC1:2 | ; | Defines the conversion in-progress flag bit. | | AD | EQU | ADC1:0 | ; | Defines the bit for activating A/D conversion (software | | | | | | activation). | | EXT | EQU | ADC2:1 | ; | Defines the bit for enabling continuous activation. | | ; | ] | Main program | | | | | CSEG | | ; | [CODE SEGMENT] | | | : | | | | | | SETB | AN0 | ; | Sets the P40/AN0 pin to the analog input. | | | CLRI | | ; | Disables interrupts. | | | SETB | ADE0 | ; | Enables the AN0 pin. | | | CLRB | EXT | ; | Disables continuous activation. | | AD_W | AIT | | | | | | BBS | ADMV,AD_WAIT | ; | Loop for verifying that the A/D converter is stopped. | | | MOV | ADC1,#00000000B | ; | Selects analog input channel 0 (AN0), clears the | | | | | | interrupt request flag, does not perform software | | | | | | activation. | | | MOV | ADC2,#00000001B | ; | Disables the interrupt request output, selects A/D | | | | | | conversion functions, and selects software activation. | | | SETI | | ; | Enables interrupts. | | | : | | | | | | SETB | AD | ; | Activates software. | | AD_C | ONV | | | | | | BBS | ADMV,AD_CONV | ; | Loop for waiting for completion of A/D conversion | | | | | | (at about 12.2 $\mu$ s/12.5 MHz) | | | CLRB | ADI | ; | Clears the interrupt request flag. | | | | | | | ### CHAPTER 12 A/D CONVERTER | | MOV | A,ADDL | ; | Reads A/D conversion data (low-order 8 bits). | |---|------|--------|---|------------------------------------------------| | | MOV | A,ADDH | ; | Reads A/D conversion data (high-order 2 bits). | | | : | | | | | | : | | | | | | ENDS | | | | | ; | | | | | | | END | | | | # CHAPTER 13 UART This chapter describes the functions and operations of UART. - 13.1 Overview of UART - 13.2 Configuration of UART - 13.3 Pins of UART - 13.4 Registers of UART - 13.5 Interrupt of UART - 13.6 Operations of UART Functions - 13.7 Program Example for UART # 13.1 Overview of UART UART is a general-purpose communication interface for serial data. UART allows variable-length serial data to be transferred synchronously or asynchronously with a clock. The transfer format is NRZ. The dedicated baud rate generator, external clock, or internal timer (8-bit PWM timer) settings determine the data transfer format. ### **■** Functions of UART UART supports (serial I/O) functions for sending serial data to, or receiving serial data from a CPU or peripheral functions. The full-duplex double-buffer enables bi-directional full-duplex communication. - Synchronous data transfer mode or asynchronous data transfer mode can be selected. - The internal baud rate generator allows one of 14 baud rates to be selected. Also, external clock input and 8-bit PWM timer output allow user-defined baud rates to be specified. - The length of data is variable. When no parity is used, 7 bits to 9 bits are available. When parity is used, 6 bits to 8 bits are available (Table 13.1-1). - The data transfer format is NRZ (Non Return to Zero). Table 13.1-2 provides the transfer rates of the dedicated baud rate generator, and Table 13.1-3 provides the transfer rates of the external clock. Table 13.1-1 UART Operating Modes | Operating mode | Data le | ngth | Synchronization mode | Stop bit length | | |----------------|-----------------|-------------|--------------------------|-------------------|--| | Operating mode | Parity not used | Parity used | Synchronization mode | | | | 0 | 7 bits | 6 bits | Synchronous/asynchronous | 1 bit or 2 bits * | | | 1 | 8 bits | 7 bits | Synchronous/asynchronous | 1 bit or 2 bits * | | | 2 | 8+1 bits | - | Synchronous/asynchronous | 1 bit or 2 bits * | | | 3 | 9 bits | 8 bits | Synchronous/asynchronous | 1 bit or 2 bits * | | <sup>\*:</sup> Only one bit is allowed for the stop bit length when data is received. The second bit is ignored even if it is received. #### ■ Serial Switch UART and 8-bit serial I/O use the same pins, thus they cannot be simultaneously used. The serial switch circuit needs be used to select either of them. When UART is selected using the serial switch, P30/UCK/SCK is used as the UART serial clock I/O pin (UCK), P31/UO/SO is used as the UART data output pin (UO), and P32/UI/SI is used as the UART data input pin (UI). #### Note: In this chapter, the pin function switch and register functions are explained on the presupposition that UART is selected using the serial switch circuit. #### **■** Choice of the Transfer Clock Rate Figure 13.1-1 Baud Rate Generator and Serial Clock Generator Example of the baud rates selectable when the dedicated baud rate generator is used Table 13.1-2 lists the baud rates selectable when the dedicated baud rate generator is used. Table 13.1-2 Transfer Cycles and Transfer Rates Available for the Dedicated Baud Rate Generator (when $F_{CH} = 12.5 \text{ MHz}$ ) | | | | | Transfer rate (μs/baud) | | | | | | |-----|-----|-----|-------------------------------------------|----------------------------|----------------------|--------------------------------------------|----------------------|--|--| | | | | | Clock divid<br>(PR2=0, PR1 | | Clock divider = 1<br>(PR2=0, PR1=0, PR0=0) | | | | | RC2 | RC1 | RC0 | Divider for baud rate<br>(multiplier = n) | Asynchronous transfer | Synchronous transfer | Asynchronous transfer | Synchronous transfer | | | | 0 | 0 | 0 | 1(0) | 83/12019 | 0.8/1.25M | 33/30048 | 0.32/3.1M | | | | 0 | 0 | 1 | 2(1) | 166/6010 | 1.6/625k | 67/15024 | 0.64/1.6M | | | | 0 | 1 | 0 | 4(2) | 333/3005 | 3.2/313k | 133/7512 | 1.28/781k | | | | 0 | 1 | 1 | 8(3) | 666/1503 | 6.4/156k | 266/3756 | 2.56/391k | | | | 1 | 0 | 0 | 16(4) | 1331/751 | 12.8/78k | 532/1878 | 5.12/195k | | | | 1 | 0 | 1 | 32(5) | 2662/375 | 25.6/39k | 1065/939 | 10.24/98k | | | | 1 | 1 | 0 | 2(1) | 13/78125 | 1.6/625k | 5.12/195k | 0.64/1.6M | | | | 1 | 1 | 1 | 16(4) | 102/9766 | 12.8/78k | 41/24k | 5.12/195k | | | Figure 13.1-2 Example of Calculating the Baud Rate #### **Notes:** The baud rate is specified using the clock gear register (CS1 and CS0), clock divider registers (PR2, PR1, and PR0), or baud rate selection registers (RC2, RC1, and RC0). For the example of calculating the baud rate, see Table 13.1-2. • Asynchronous transfer mode $$1/12019$$ bps= $0.8 \mu s \{4/F_{CH} \times 2.5(PR2=0,PR1=1,PR0=0)\} \times 1(CS1=CS0=1) \times 8(asynchronous) \times 1(RC2=RC1=RC0=0) \times 13(asynchronous)$ • Synchronous transfer mode $$1/1.25 Mbps = 0.8 \ \mu s \{4/F_{CH} \times 2.5 (PR2=0,PR1=1,PR0=0)\} \times 1 (CS1=CS0=1) \times 1 (synchronous) \times 1 (RC2=RC1=RC0=0) \times 1 (synchronous)$$ Table 13.1-3 provides an example of the baud rates selectable when an external clock is used. Table 13.1-3 Transfer Cycles and Transfer Rates Selectable for an External Clock | | Asyı | nchronous transfer m | ode | Synchronous transfer mode | | | | |-------------|--------------------------------------|-----------------------------|-----------------------|---------------------------|----------------------------|-----------------------|--| | Divider for | | Transfer cycle | Transfer rate (bps) * | Divider for baud rate | Transfer cycle | Transfer rate (bps) * | | | CR=0 | 16 | 256/F <sub>CH</sub> or more | 48828 or less | 1 | 16/F <sub>CH</sub> or more | 781 k or less | | | CR=1 | CR=1 64 1024/F <sub>CH</sub> or more | | 12207 or less | 1 | 10/1 CH of more | 781 K 01 1688 | | <sup>\*:</sup> The minimum value of $F_{CH}$ specified for 12.5 MHz is external clock cycle $16/F_{CH} = 1.28 \mu s$ . F<sub>CH</sub>: Oscillation frequency Figure 13.1-3 Example of Calculating the Baud Rate (when an External Clock is Selected) $$\frac{1}{\text{Value of baud rate}} = \text{External clock input} \times \text{CR} \left( \begin{array}{c} \text{CR=0} \cdots 16 \\ \text{CR=1} \cdots 64 \end{array} \right)$$ $$F_{\text{CH}} : \text{Oscillation frequency}$$ Table 13.1-4 provides an example of the baud rates selectable when the 8-bit PWM timer is used. Table 13.1-4 Transfer Cycles and Transfer Rates Selectable for the 8-bit PWM Timer | PWM timer | | Asynchr | onous transfer mode | Synchronous transfer mode | | | |--------------------------------|-------------------|---------|---------------------|---------------------------|---------------------|--| | count clock<br>cycle | Divider for clock | | Transfer rate (bps) | Divider for clock | Transfer rate (bps) | | | 1t | CR=0 | 16 | 97656 to 763 | 2 | 781k to 6.1k | | | 1t <sub>INST</sub> | CR=1 | 64 | 24414 to 191 | 2 | | | | 16t <sub>INST</sub> | CR=0 | 16 | 6103 to 47.8 | 2 | 48828 to 381.5 | | | TOUNST | CR=1 | 64 | 1526 to 11.9 | 2 | 40020 to 301.3 | | | 64t <sub>INST</sub> | CR=0 | 16 | 1526 to 11.9 | 2 | 12207 to 95.4 | | | 04tINST | CR=1 | 64 | 381.5 to 3 | 2 | | | | 8/16-bit capture timer/counter | CR=0 | 16 | 48828 to 381.5 | 2 | 391k to 3k | | | | CR=1 | 64 | 12207 to 95.4 | 2 | | | t<sub>INST</sub>: Instruction cycle The system clock control register (SYCC) selects the maximum clock speed (CS1 and CS0 = $11_B$ , 1 instruction cycle = $4/F_{CH}$ ) in active mode. Figure 13.1-4 shows an example of calculating the baud rate when the PWM timer is selected. Figure 13.1-4 Example of Calculating the Baud Rate (when the PWM Timer is Selected) The value of the baud rate is determined by the clock input specified in the clock dividing rate register (CS1 and CS0). The clock input is determined with an external clock (PWM timer). For calculation, see Table 13.1-3 and Table 13.1-4. - When an external clock is selected ( $F_{CH} = 12.5 \text{ MHz}$ ) 1/49kbps=1.28 $\mu$ s (min.) × 16 (CR=0) - When the PWM timer is selected ( $F_{CH}$ = 12.5 MHz) 1/98kbps=0.32 $\mu$ s (4/ $F_{CH}$ ) $\times$ 1 (P1=0,P0=0) $\times$ 1 (COMR=0) $\times$ 2 $\times$ 16 (CR=0) 1/24414 bps=0.32 $\mu$ s (4/ $F_{CH}$ ) $\times$ 1 (P1=0,P0=0) $\times$ 1 (COMR=0) $\times$ 2 $\times$ 64 (CR=1) #### **Configuration of UART** 13.2 **UART** consists of the following ten registers and components: - Serial mode control register (SMC) - Serial rate control register (SRC) - Serial status and data register (SSD) - Serial input data register (SIDR) - Serial output data register (SODR) - Baud rate generator - Reception control circuit - Transmission control circuit - Clock divider selection register (UPC) - **UART** prescaler # **■ Block Diagram of UART** Control bus UART interrupt Reception interrupt RIE Transmission Transmission interrupt Transmission control circuit clock P30/UCK/SCK Reception control Pin Received byte counter Transmitted byte counter Baud rate Figure 13.2-1 Block Diagram of UART IRQ6 IRQ5 generator Parity transmission timing Start bit detection P31/UO/SO UART circuit Pin prescaler Parity Parity Reception clock **PREN** PR2,1,0 Shift register Shift register Clock Completion of receipt of divider Register Register selection one byte <Serial input data register (SIDR)> P32/UI/SI <Serial output register data register (SODR)> Pin (UPC) Internal data bus **RDRF** PEN ORFE SBL Serial rate Serial mode Serial status TDREX control MC1/0 control and data TIE register register CR register SMDE (SMC) (SRC) RIE (SSD) CS1/0 SCKE TΡ RC2 to 0 SOE RP Control bus #### Serial mode control register (SMC) The SMC register controls UART operating mode. This register specifies the parity setting, stop bit length, operating mode (data length), and synchronous/asynchronous mode, and enables/disables UART serial clock output and serial data output. #### Serial rate control register (SRC) The SRC register controls the UART data transfer speed (baud rate). This register selects the input clock and specifies the transfer rate to be applied when the baud rate generator is used. #### Serial status and data register (SSD) The SSD register indicates UART transmitting/receiving status, status in an error, parity received, or data received at bit8. This register also enables/disables interrupts or specifies and confirms parity transmitted or data transmitted with bit8. #### Serial input data register (SIDR) The SIDR register stores received data. Serial input is converted, then stored into this register. However, the most significant bit of 9-bit data is stored in the SSD RD8/RP bit. #### Serial output data register (SODR) The SODR register specifies data to be transmitted. Data written into this register is converted to serial format, then output. The most significant bit of 9-bit data is set in the SSD TD8/TP bit. #### Clock generator The clock generator generates the transmit/receive clock in accordance with the dedicated baud rate generator, external clock, and 8-bit PWM timer output. #### Reception control circuit The reception control circuit consists of the received byte counter, start bit detection circuit, and received parity handling circuit. The received byte counter takes count of received data. When a unit of data that corresponds to the specified data length is fully received, an interrupt request is generated. The start bit detection circuit detects start bits in serial input signals. When the start bit detection circuit detects a start bit, it writes data into the SIDR with shifts in accordance with the transfer rate. When parity is used, the received parity handling circuit stores the parity bit in the data received. It also stores the most significant bit of 9-bit data received. #### Transmission control circuit The transmission control circuit consists of the transmitted byte counter and transmitted parity handling circuit. The transmitted byte counter takes count of data to be transmitted. When a unit of data that corresponds to the specified data length is fully transmitted, an interrupt request is generated. When parity is used, the transmitted parity handling circuit generates a parity bit for the data to be transmitted. It sets the most significant bit for data transmitted when it is made up of 9 bits. #### UART interrupt sources #### [Reception] When data with the specified length is correctly received or when the overrun error or framing error occurs while data is being received, the reception interrupt request (IRQ6) is generated if the reception interrupt request is enabled (SSD: RIE = 1). #### [Transmission] When data to be transmitted is written into the SODR register, sent to the internal shift register, and the next data then becomes writable, the transmission interrupt request (IRQ5) is generated if the transmission interrupt request is allowed (SSD: TIE = 1). #### UART prescaler, baud rate generator, clock divider selection register The clock input to the baud rate generator is changeable by switching the rate of division using the clock divider selection registers. # 13.3 Pins of UART Pins relating to UART are the clock I/O pin (P30/UCK/SCK), serial data output pin (P31/UO/SO), and serial data input pin (P32/UI/SI). ### ■ UART Relating Pins #### P30/UCK/SCK This pin functions as the general-purpose I/O port (P30), UART clock I/O pin (UCK), or 8-bit serial clock I/O pin (SCK). When clock output is enabled (SMC: SCKE = 1), this pin functions as the UART clock output pin (UCK) regardless of the value in the corresponding port direction register. When this pin functions as the UART clock, do not use any external clock (SRC: CS1 and CS0 must be other than $00_B$ ). When using this pin as the UART clock input pin, disable clock output (SMC: SCKE = 0) and set it as the input port using the corresponding port direction register (DDR3: bit0 = 0). In this case, be sure to select the external clock (SRC: CS1 and CS0 = $00_B$ ). #### P31/UO/SO This port functions as the general-purpose I/O port (P31), UART serial data output pin (UO), or 8-bit serial data output pin (SO). When serial data output is enabled (SMC: SOE = 1), this pin functions as the UART serial data output pin (UO) regardless of the value in the corresponding port direction register. #### P32/UI/SI This port functions as the general-purpose I/O port (P32), UART serial data input pin (UI), or 8-bit serial data input pin (SI). When using this pin as the UART serial data input pin, set this pin as the input port by using the corresponding port direction register (DDR3: bit2 = 0). # ■ Block Diagram of the UART-relating Pins P30/UCK/SCK UCK € PDR D P32/UI/SI Stop mode (SPL = 1) PDR read Resource output Resource Pull-up resistor Resource output allowed output enable PDR read (At read-modify-write) Pch Output latch Internal data bus PDR write Pin P30/UCK/SCK Nch DDR write DDR P31/UO/SO P32/UI/SI $\pi$ Stop mode (SPL = 1) PUL read PUL PUL write Figure 13.3-1 Block Diagram of UART-relating Pins When use of the pull-up resistor is selected in the pull-up setting register, the pin status does not become Hi-Z but "H" level (pull-up state) in stop mode (SPL = 1). However, the pull-up resistor is not applied during reset; accordingly, the pin status becomes Hi-Z. # 13.4 Registers of UART # Figure 13.4-1 shows the UART-relating registers. # ■ UART-relating Registers Figure 13.4-1 UART-relating Registers | SMC (serial | mode con | trol regist | er) | | | | | | | |-------------------|---------------------|-------------|--------|------|------|------|--------|--------|-----------------------| | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0028н | PEN | SBL | MC1 | MC0 | SMDE | | SCKE | SOE | 00000-00 <sub>B</sub> | | | R/W | R/W | R/W | R/W | R/W | | R/W | R/W | | | SRC (serial i | ate contro | l register | ) | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0029 <sub>H</sub> | _ | _ | CR | CS1 | CS0 | RC2 | RC1 | RC0 | 011000 <sub>B</sub> | | | | | R/W | R/W | R/W | R/W | R/W | R/W | | | SSD (serial s | status and | data regi | ster) | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 002A <sub>H</sub> | RDRF | ORFE | TDRE | TIE | RIE | | TD8/TP | RD8/RP | 00100-1X <sub>B</sub> | | | R | R | R/W | R/W | R/W | | R/W | R | | | SIDR (serial | input data | register) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 002B <sub>H</sub> | | | | | | | | | XXXXXXXX | | | R | R | R | R | R | R | R | R | | | SODR (seria | ıl output d | ata registe | er) | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 002B <sub>H</sub> | | | 2.10 | | | | | | XXXXXXXX | | | W | W | W | W | W | W | W | W | _ | | UPC (clock o | divider sele | ection rea | ister) | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 002Сн | | | | | PREN | PR2 | PR1 | PR0 | 0010 <sub>B</sub> | | 002011 | | | | | R/W | R/W | R/W | R/W | 00.00 | | SSEL (serial | switch red | nister) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | | 003B <sub>H</sub> | DIL1 | | | | | DILZ | | SSEL | 0 <sub>B</sub> | | 000D <sub>H</sub> | | | | | | | | R/W | ОВ | | R/W : | | | | | | | | | | | | Read only | | | | | | | | | | | Write only | | | | | | | | | | - | Unused<br>Undefined | | | | | | | | | | ^ . | | | | | | | | | | | | | | | | | | | | | # 13.4.1 Serial Mode Control Register (SMC) The serial mode control register (SMC) specifies the parity setting, stop bit length, operating mode (data length), and synchronous/asynchronous mode, and enables/disables UART serial clock output and serial data output. ■ Serial Mode Control Register (SMC) Figure 13.4-2 Serial Mode Control Register (SMC) Table 13.4-1 Explanation of Functions of Each Bit in the Serial Mode Control Register (SMC) | | Bit name | Description | | | | | |---------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | bit7 | PEN:<br>Parity enable bit | This bit selects whether the parity bit is to be added (at transmission) and detected (at reception) when serial data is input/output. | | | | | | bit6 | SBL:<br>Stop bit length selection bit | This bit selects the stop bit length for data to be transmitted. Note: When data is received, only the first bit of stop bits is detected and the second and later bits are ignored. | | | | | | bit5,<br>bit4 | MC1, MC0: Operating mode selection bits | <ul> <li>These bits specify operating mode (data length).</li> <li>There are 7 types of data length selectable in combination with a parity bit.</li> </ul> | | | | | | bit3 | SMDE:<br>Synchronization mode selection<br>bit | <ul> <li>This bit specifies synchronous transfer or asynchronous transfer mode.</li> <li>When this bit is "0", synchronous transfer mode is set. When this is "1", asynchronous transfer mode is set.</li> </ul> | | | | | | bit2 | Unused bit | <ul> <li>The value read out from this bit is undefined.</li> <li>Writing a value into this bit does not affect any operations.</li> </ul> | | | | | | bit1 | SCKE:<br>Clock output enable bit | <ul> <li>This bit controls I/O of the serial clock.</li> <li>When this bit is "0", P30/UCK/SCK pin functions as the serial clock input pin. When this bit is "1", it functions as the serial clock output pin.</li> <li>Notes:</li> <li>When the UCK pin functions as the serial clock input pin (SCKE = 0), set the P30/UCK/SCK pin as the input port. Also, select the external clock using the clock input selection bit (SRC: CS1 and CS0 = 00<sub>B</sub>).</li> <li>When the UCK pin is set as the serial clock output pin (SCKE = 1), select a clock other than the external clock (SRC: CS1 and CS0 must not be 00<sub>B</sub>).</li> <li>Note: When the UCK pin is specified as the serial clock output (SCKE = 1), it functions as the UCK output pin regardless of the state of the general-purpose port (P30).</li> </ul> | | | | | | bit0 | SOE:<br>Serial data output enable bit | When this bit is "0", the P31/UO/SO pin functions as a general-purpose port (P31). When this bit is "1", it functions as the serial data output pin (UO). Note: When serial data output is enabled (SOE = 1), the pin functions as the UO pin regardless of the state of the general-purpose port (P31). | | | | | # 13.4.2 Serial Rate Control Register (SRC) The serial rate control register (SRC) controls the data transfer rate (baud rate) in asynchronous transfer mode. The SRC selects the input clock and sets the transfer rate for the dedicated baud rate generator. ### ■ Serial Rate Control Register (SRC) Figure 13.4-3 Serial Rate Control Register (SRC) Table 13.4-2 Explanation of Functions of Each Bit in the Serial Rate Control Register (SRC) | | Bit name | Description | | | | | |--------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | bit7,<br>bit6 | Unused bits | <ul> <li>The values read out from these bits are undefined.</li> <li>Writing values to these bits does not affect any operations.</li> </ul> | | | | | | bit5 | CR:<br>Clock rate input<br>selection bit | <ul> <li>This bit selects the clock rate in asynchronous transfer mode. However, when the dedicated baud rate generator is used (CS1 and CS0 = 11<sub>B</sub>), it is fixed at 1/8 regardless of the value in the CR bit. Specifying an external clock or 8-bit PWM timer output as the clock input, the baud rate is set to 1/16 or 1/64 of the corresponding clock frequency, depending on the CR value.</li> <li>This bit is not significant in synchronous transfer mode.</li> </ul> | | | | | | bit4,<br>bit3 | CS1,CS0:<br>Clock input selection<br>bits | <ul> <li>These bits select the clock input.</li> <li>The clock input can be an external clock (UCK pin), 8-bit PWM timer, or dedicated baud rate generator.</li> </ul> | | | | | | bit2<br>to<br>bit0 | RC2,RC1,RC0:<br>Baud rate selection bits | <ul> <li>There are 8 types of baud rate in asynchronous transfer mode and 6 types of baud rate in synchronous transfer mode: 14 types of baud rate are selectable in total.</li> <li>These bits are effective only when the dedicated baud rate generator is used for the clock input. These bits are not significant when an external clock or 8-bit PWM timer output is used.</li> </ul> | | | | | # 13.4.3 Serial Status and Data Register (SSD) The serial status and data register (SSD) controls data transmission/reception of UART and status in an error, enables/disables interrupts, and specifies and checks settings for parity or bit-8 transmitting data. ■ Serial Status and Data Register (SSD) Figure 13.4-4 Serial Status and Data Register (SSD) Table 13.4-3 Explanation of Functions of Each Bit in the Serial Status and Data Register (SSD) | | Bit name | Description | |------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | RDRF:<br>Received data flag bit | <ul> <li>This bit indicates the state of serial input data register (SIDR).</li> <li>When this bit is "1", reading the SSD register, then the SIDR register clears RDRF.</li> <li>When this bit and reception interrupt request enable bit (RIE) are "1", the reception interrupt request is output.</li> <li>This bit is intended only for read. Writing a value into this bit has no significance and does not affect any operation.</li> </ul> | | bit6 | ORFE:<br>Overrun/Framing error<br>flag bit | <ul> <li>This bit indicates that the overrun or framing error occurs.</li> <li>When an error occurs (ORFE = 1), no data is transferred from the reception shift register to the SIDR register. Therefore, when an error occurs, the RDRF bit is not set. When this bit is "1", reading the SSD register then SIDR register clears the ORFE bit with "0".</li> <li>When this bit and reception interrupt request enable bit (RIE) are "1", the reception interrupt request is output.</li> <li>This bit is intended only for read. Writing a value into this bit has no significance and does not affect any operation.</li> </ul> | | bit5 | TDRE:<br>Transmitted data flag<br>bit | <ul> <li>This bit indicates the state of serial output data register (SODR).</li> <li>When this bit is "1", reading the SSD register and writing data into the SODR register output the data to the serial data output pin (UO).</li> <li>When this bit and transmission interrupt request enable bit (TIE) are "1", the transmission interrupt request is output.</li> </ul> | | bit4 | TIE:<br>Transmission interrupt<br>request enable bit | <ul> <li>This bit enables or disables the transmission interrupt request to the CPU.</li> <li>When this bit and transmission data flag bit (TDRE) are "1", the transmission interrupt request is output.</li> </ul> | | bit3 | RIE:<br>Reception interrupt<br>request enable bit | <ul> <li>This bit enables or disables the reception interrupt request to the CPU.</li> <li>When this bit and reception data flag bit (RDRF) are "1", the reception interrupt request is output.</li> <li>When this bit and error flag bit (ORFE) are "1", the reception interrupt request for an error is output.</li> </ul> | | bit2 | Unused bit | <ul> <li>The value read out from this bit is undefined.</li> <li>Writing a value into this bit does not affect any operations.</li> </ul> | | bit1 | TD8/TP:<br>Bit-8 transmitting data/<br>parity bit | <ul> <li>When parity is not used and operating mode is 2 or 3 (the length of data to be transmitted/received is 9), this bit is handled as bit8 in the SODR register. When operating mode is not 2 or 3 and parity is not used, this bit is not significant.</li> <li>When parity is used, this bit selects even parity or odd parity for the transmitted data.</li> </ul> | | bit0 | RD8/RP:<br>Bit-8 receiving data/<br>parity bit | <ul> <li>When parity is not used and operating mode is 2 or 3 (the length of data to be transmitted/received is 9), this bit is handled as bit8 in the SIDR register. When operating mode is not 2 or 3 and parity is not used, this bit is not significant.</li> <li>When parity is used, this bit indicates the parity of received data.</li> </ul> | # ■ Receiving Status Figure 13.4-5 shows the states (receiving status) of serial input data obtained from the received data flag bit (RDRF) and error flag bit (ORFE). Figure 13.4-5 Receiving Status | RDRF | ORFE | Received data flag bit/Overrun/Framing error flag bit | | | |-----------------|------|-------------------------------------------------------|--|--| | 0 | 0 | No data | | | | 0 | 1 | Framing error | | | | 1 | 0 | Normal data | | | | 1 | 1 | Overrun error (previous data remaining) | | | | : Initial value | | | | | # 13.4.4 Serial Input Data Register (SIDR) The serial input data register (SIDR) is for inputting (receiving) serial data. ## ■ Serial Input Data Register (SIDR) Figure 13.4-6 shows the configuration of the serial input data register bits. Figure 13.4-6 Serial Input Data Register (SIDR) The SIDR stores received data. The serial data input pin (UI pin) receives serial data signals, the shift register converts them, then this register stores them. ### When operating mode is 0, 1, or 3 For both the RDRF (Received data flag bit) and ORFE (Overrun/framing error flag bit), these flags go on and an interrupt request to the CPU is generated when data is fully transmitted or received, then the stop bit at the end is detected. When the RDRF is active, the data received is transmitted to the SIDR. When the received data is correctly stored in this register, "1" is set for the received data flag bit (RDRF). If the reception interrupt request is allowed, the reception interrupt is generated. When the RDRF bit has been checked in interrupt processing or the program and the received data has been stored into this register, read the contents in this register after reading the SSD register, then clear the RDRF flag. ### When operating mode is 2 For both RDRF and ORFE, these flags go on when data is fully transmitted or received with the final data bit (D8) set to "1" and the stop bit at the end is detected. However, when the framing error occurs, the flag goes on regardless of the final data bit. An interrupt request to the CPU is generated when the flag goes on and the interrupt request is allowed. # 13.4.5 Serial Output Data Register (SODR) The serial output data register (SODR) sends out (transmits) serial data. ### ■ Serial Output Data Register (SODR) Figure 13.4-7 shows the configuration of the serial output data register bits. Figure 13.4-7 Serial Output Data Register (SODR) When transmission is enabled, writing data to be transmitted into this register after reading the SSD register sends the data to be transmitted to the transmission shift register, converts it into the serial format, then outputs it from the serial data output pin (UO pin). When the transmitted data is written into the SODR register, the transmitted data flag bit is cleared with "0". After the transmitted data is sent to the transmission shift register, the transmitted data flag bit is set to "1", the data transmitted next then becomes writable. At this time, if the transmission interrupt request is enabled, an interrupt is generated. Write the data transmitted next when a transmission interrupt occurs or while the transmitted data flag bit is "1". # 13.4.6 Clock Divider Selection Register (UPC) The clock divider selection register is used to generate the UART reference clock by dividing the oscillation frequency. It also enables/disables operation of the prescaler for creating the reference clock. ■ Clock Divider Selection Register (UPC) Figure 13.4-8 Clock Divider Selection Register (UPC) Table 13.4-4 Explanation of Functions of Each Bit in the Clock Divider Selection Register (UPC) | | Bit name | Description | | | |--------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | bit7<br>to<br>bit4 | Unused bits | <ul> <li>The values read out from these bits are undefined.</li> <li>Writing values into these bits does not affect any operation.</li> </ul> | | | | bit3 | PREN:<br>UART prescaler<br>operation enable bit | <ul> <li>Enables/disables operation of the prescaler that creates the UART reference clock by dividing the oscillation frequency.</li> <li>When this bit is "1", the UART prescaler supplies the reference clock that corresponds to the frequency selected using the oscillation frequency selection bit to the baud rate generator. When this bit is "0", the prescaler does not operate, thus the internal baud rate generator cannot be used for data transfer or data receive purposes.</li> </ul> | | | | bit2<br>to<br>bit0 | PR2, PR1, PR0:<br>Clock divider selection<br>bits | The UART prescaler supplies to the internal baud rate generator, the reference clock that corresponds to the divider selected using these bits. | | | #### Note: The inside of UART is initialized when it is in synchronization transfer mode, asynchronous transfer mode, external clock mode, or internal clock mode with the clock from the prescaler. Therefore, turn on the PREN bit (PREN = 1) to enable operation of the prescaler before using the UART functions. # 13.4.7 Serial Switch Register (SSEL) The serial switch register (SSEL) switches the P30/UCK/SCK, P31/UO/SO, and P32/UI/SI pins between UART and 8-bit serial I/O. # ■ Serial Switch Register (SSEL) Figure 13.4-9 Serial Switch Register (SSEL) Table 13.4-5 Description of the Serial Switch Register (SSEL) Bits | Bit name | | Description | | | |--------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--| | bit7<br>to<br>bit1 | Unused bits | <ul> <li>The values read out from these bits are undefined.</li> <li>Writing values to these bits does not affect any operations.</li> </ul> | | | | bit0 | SSEL:<br>Serial switch bit | <ul> <li>When this bit is "0", UART is used.</li> <li>When this bit is "1", 8-bit serial I/O is used.</li> </ul> | | | Figure 13.4-10 Block Diagram of Serial Switch Register # 13.5 Interrupt of UART UART supports the interrupt-related error flag bit (ORFE), received data flag bit (RDRF), and transmitted data flag bit (TDRE), and the following interrupt sources: - When received data is sent from the reception shift register to the serial input data register (SIDR). (Reception interrupt) - When transmitted data is sent from the serial output data register (SODR) to the transmission shift register. (Transmission interrupt) ### ■ Transmission Interrupt When the SSD register is read and the output data is written into the SODR register, the data written into the SODR register is transferred to the internal transmission shift register. When next data becomes writable, the TDRE bit is set to "1", then an interrupt request to the CPU (IRQ5) is generated if the transmission interrupt is enabled (SSD: TIE = 1). ### ■ Reception Interrupt #### When operating mode is 0, 1, or 3 When data is correctly input up to the stop bit, the RDRF bit is set to "1". If an overrun error or framing error occurs, the ORFE bit is set to "1". These bits are set when a stop bit is detected. If the reception interrupt is enabled (SSD: RIE = 1), an interrupt request to the CPU (IRQ6) is generated. #### When operating mode is 2 For both RDRF and ORFE, data is received or transmitted with the final data bit (D8) set to "1", these flags go on when the stop bit at the end is detected. However, when the framing error occurs, the flag goes on regardless of the final data bit. An interrupt request to the CPU is generated when the flag goes on and the input data becomes "1". ### ■ UART Interrupt Related Registers and Vector Table Addresses Table 13.5-1 provides the registers relating to the UART interrupts and vector table addresses. For details of the interrupt operation, see Section "3.4.2 Steps in the Interrupt Operation". Table 13.5-1 UART Interrupt Related Registers and Vector Table Addresses | Interrupt name | Interrupt level setting register | | | Vector table address | | |----------------|----------------------------------|------------|------------|----------------------|-------------------| | interrupt name | Register | Bit | | Upper digits | Lower digits | | IRQ5 | ILR2 (007C <sub>H</sub> ) | L51 (bit3) | L50 (bit2) | FFF0 <sub>H</sub> | FFF1 <sub>H</sub> | | IRQ6 | ILR2 (007C <sub>H</sub> ) | L61 (bit5) | L60 (bit4) | FFEE <sub>H</sub> | FFEF <sub>H</sub> | # 13.6 Operations of UART Functions UART supports four types of operating mode. Mode 0, mode 1, and mode 3 are general serial transfer mode in which any data length can be selected in the range of 6 bits with parity used, to 9 bits without parity used. (See Table 13.1-1.) #### ■ Transferred Data Format UART can handle data in the NRZ (Non Return to Zero) format only. Data to be transferred always begins with the start bit ("L" level), specified number of data bits are transferred with LSB first, then data transfer is ended with the stop bit ("H" level). Figure 13.6-1 shows the relationship between the transmit/receive clock and transferred/received data when operating mode 0 without parity used, two stop bits, synchronous transfer mode, and transferred data 01001101<sub>B</sub> (8 bits) are specified. Note that Figure 13.6-1 does not apply to the relationship between the serial clock and serial I/O signal in asynchronous transfer mode. Figure 13.6-1 Transferred Data Format # ■ Theory of Operation for Operating Mode 0, 1, 2, and 3 mode 3. In operating mode 0, 1, 2, or 3, UART operates as a general serial communication function. Figure 13.6-2 shows the settings required in UART operating mode 0, 1, 2, or 3. bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 SMC PEN MC0 SMDE SCKE SOE SBL MC1 0 $\bigcirc$ $\odot$ $\odot$ $\odot$ SRC CR CS1 CS0 RC2 RC1 RC0 $\bigcirc$ $\bigcirc$ $\bigcirc$ $\bigcirc$ $\bigcirc$ 0 TDRE **RDRF** SSD ORFE TIE RIE TD8/TP RD8/RP 0 0 Stores received data. **SIDR SODR** Writes data to be transmitted. DDR3 $\bigcirc$ $\bigcirc$ **SSEL** SSEL 0 : Used bit : Set "0" : For MC1 and MC0, set $00_B$ in mode 0, $01_B$ in mode 1, $10_B$ in mode 2, and $11_B$ in Figure 13.6-2 Operating Mode 0, 1, 2, or 3 # 13.6.1 Transmission Operations (Operating Mode 0, 1, 2, and 3) When writing data to be transmitted into the SODR register after reading the SSD register sends the data written into the SODR register to the transmission shift register, parallel-serial conversion then starts. The data converted is output at the serial data output pin from the lowest bit in sequence (with LSB first). When the next data becomes writable, "1" is set to the TDRE bit, then an interrupt request to the CPU is generated if the transmission interrupt is allowed (SSD: TIE = 1). ### ■ Transmission Operations in Operating Mode is 0, 1, 2, or 3 Figure 13.6-3 shows the transmission operations when operating mode is 1, parity is not used, and the number of stop bits is "1". Figure 13.6-3 Transmission Operations in Operating Mode 0, 1, 2, or 3 # 13.6.2 Reception Operations (Operating Mode 0, 1, or 3) When data is received at the serial data input pin, the internal reception shift register converts it from serial to parallel. If the data is correctly transmitted up to the stop bit(s), data in the internal shift register is transferred to the SIDR register, then "1" is set to the RDRF bit. ### ■ Reception Operations (Operating Mode 0, 1, or 3) If an overrun error or framing error occurs, the received data is not transmitted to the SIDR register, but the ORFE bit is set to "1". Either of the RDRF bit and ORFE bit goes on when the final stop bit is detected after data is fully received. If the reception interrupt is enabled (SSD: RIE = 1), an interrupt request to the CPU (IRQ6) is generated. When the RDRF bit goes on, the received data has been transmitted to the SIDR register. In operating mode 2, when the RIE bit is "1", RDRF bit or ORFE bit is "1", and reception interrupt pin is "1", the mode 2 UART reception interrupt request is output to the CPU. #### Note: In operating mode 1, the parity bit is read as data in the 7th bit. Set up the program so that the 7th bit is not read. Figure 13.6-4, Figure 13.6-5, and Figure 13.6-6 show the reception operations when parity is not used and the number of stop bits is "1" in operating mode 0, 1, or 3. Figure 13.6-4 Reception Operations in Operating Mode 0, 1, or 3 Figure 13.6-5 Operations in Operating Mode 0, 1, or 3 when the Overrun Error Occurs Figure 13.6-6 Operations in Operating Mode 0, 1, or 3 when the Framing Error Occurs ### Note: After initialization is cancelled due to a reset, time for 11 shift-clock cycles is required to initialize the internal controller. Therefore, be sure to enable the UART prescaler operation (PREN = 1) using the oscillation frequency register after a reset. ## 13.6.3 Reception Operations (Operating Mode 2 Only) When data is received at the serial data input pin, the internal reception shift register converts it from serial to parallel. If the data is correctly transmitted up to the stop bit(s), data in the internal shift register is transferred to the SIDR register, then "1" is set to the RDRF bit. #### ■ Reception Operations (Operating Mode 2 Only) If an overrun error or framing error occurs, the received data is not transmitted to the SIDR register, but the ORFE bit is set to "1". For both RDRF and ORFE, data is fully received/transmitted with the final data bit (D8) set to "1", these flags go on when the stop bit at the end is detected. However, when the framing error occurs, the flag goes on regardless of the final data bit. An interrupt request to the CPU is generated when the flag goes on and interrupt request is enabled. If the reception interrupt is enabled (SSD: RIE = 1), an interrupt request to the CPU (IRQ5) is generated. When the RDRF bit goes on, the received data is transmitted to the SIDR register. Figure 13.6-7 to Figure 13.6-9 show the reception operations when parity is not used and the number of stop bits is "1" in operating mode 2. Data START 0 1 2 3 4 5 6 7 8 STOP RDRF Reception interrupt Figure 13.6-7 Reception Operations in Operating Mode 2 Figure 13.6-9 Operations in Operating Mode 2 when the Framing Error Occurs #### Note: After initialization is cancelled due to a reset, time for 11 shift-clock cycles is required to initialize the internal controller. Therefore, be sure to enable the UART prescaler operation (PREN = 1) using the oscillation frequency register after a reset. ## 13.7 Program Example for UART ## This section provides program example for UART. #### ■ Program Example for UART #### Program specifications - Serial data transfer is implemented using the UART communication functions. - The P30/UCK/SCK, P31/UO/SO, and P32/UI/SI pins are used for communication. - The transfer rate is set to 300 bps using the internal baud rate generator. - $13_{\rm H}$ is transmitted from the UO pin, and data is received by interrupts. - The baud rate is the oscillation frequency ( $F_{CH} = 12.5 \text{ MHz}$ ) at the maximum gear speed (1 instruction cycle = $4/F_{CH}$ ). The clock divider is 2.5. (1/375 bps = 8320 $t_{INST}$ ) #### Coding example | PDR3 | EQU | 000CH | ; | Port data register address | |-------|-------------|-----------------|---|-----------------------------------------------------------------------| | DDR3 | EQU | 000DH | ; | Port direction register address | | SSEL | EQU | 003BH | ; | Serial selection register address | | SMC | EQU | 0028H | ; | Serial mode control register address | | SRC | EQU | 0029H | ; | Serial rate control register address | | SSD | EQU | 002AH | ; | Serial status and data register address | | SIDR | EQU | 002BH | ; | Serial input data register address | | SODR | EQU | 002BH | ; | Serial output data register address | | UPC | EQU | 002CH | ; | Clock divider selection register address | | ILR2 | EQU | 007CH | ; | Interrupt level setting register address | | INT_V | DSEG | ABS | ; | [DATA SEGMENT] | | | ORG | 0FFEEH | | | | IRQ6 | DW | WARI2 | ; | Reception interrupt vector setting | | IRQ5 | DW | WARI1 | ; | Transmission interrupt vector setting | | INT_V | <b>ENDS</b> | | | | | ; | M | ain program | | | | | CSEG | | ; | [CODE SEGMENT] | | | | | ; | The stack pointer (SP) and related components have to be initialized. | | | : | | | | | | CLRI | | ; | Disable interrupts. | | | MOV | ILR2,#11101011B | | Set an interrupt level (level 1). | | | MOV | UPC,#11111010B | ; | Allow operation with the clock whose frequency is divided by 2.5. | | | MOV | SSEL,#00000000B | ; | Select UART. | | | MOV | DDR3,#00000000B | ; | Set the UI pin as the input pin. | | | MOV | SMC,#01011011B | ; | Set non-parity, the number of stop bits 1, and operating | | | | | | | mode 1. Set asynchronous mode, enable clock output and serial data output. MOV SRC,#00011101B ; Select the dedicated baud rate generator, and set the baud rate 375 bps. ; Disable the transmission interrupt request and enable the MOV SSD,#00001000B reception interrupt request. MOV A,SSD ; Required before transmission (TDRE = 1 enables transmission)MOV A,SIDR ; Clear error flags. MOV SODR,#13H ; Write the data to be transmitted $(13_{\rm H})$ . **SETI** ; Enable instruction. : ------Interrupt processing routine-----WARI PUSHW A ; Save A and T. XCHW A,T PUSHW A MOV A,SSD ; Read the data to be transmitted, then clears the input data flag. MOV A,SIDR User-defined process **POPW** A ; Restore A and T. XCHW A,T**POPW** A **RETI ENDS END** ## CHAPTER 14 # 8-BIT SERIAL I/O This chapter describes the functions and operation of the 8-bit serial I/O. - 14.1 Overview of 8-Bit Serial I/O - 14.2 Configuration of 8-Bit Serial I/O - 14.3 Pins of 8-Bit Serial I/O - 14.4 Registers of 8-Bit Serial I/O - 14.5 Interrupt of 8-Bit Serial I/O - 14.6 Operations of Serial Output Functions - 14.7 Operations of Serial Input Functions - 14.8 8-Bit Serial I/O Operation in Each Mode - 14.9 Notes on Using 8-Bit Serial I/O - 14.10 Example of 8-Bit Serial I/O Connection - 14.11 Program Example for 8-Bit Serial I/O #### 14.1 Overview of 8-Bit Serial I/O The 8-bit serial I/O has a function that serially transfers 8-bit data in synchronization with a shift clock. It can select one shift clock from three internal shift clocks and one external shift clock. It can also select LSB first or MSB first as the data shift direction. #### ■ Serial I/O Function The 8-bit serial I/O function serially inputs and outputs 8-bit data in synchronization with a shift clock. - Converts 8-bit parallel data to 8-bit serial data and outputs it. Also inputs 8-bit serial data, converts the data to 8-bit parallel data, and stores it. - Can select one shift clock from three internal shift clocks and one external shift clock. - Can control shift clock input/output and output internal shift clocks. - Can select LSB first or MSB first as the data shift direction. Table 14.1-1 Shift Clock Cycle and Transfer Rate | Shift clock | Clock cycle | Frequency (Hz) | Transfer rate (F <sub>CH</sub> =12.5MHz, At maximum speed*) | |-------------------------------|-----------------------------|------------------------------------|-------------------------------------------------------------| | | 2t <sub>INST</sub> | 1/ (2t <sub>INST</sub> ) | 1562.5 kbps | | Internal shift clock (output) | 8t <sub>INST</sub> | 1/ (8t <sub>INST</sub> ) | 390.6 kbps | | - | 32t <sub>INST</sub> | $1/\left(32t_{\text{INST}}\right)$ | 97.66 kbps | | External shift clock (input) | 2t <sub>INST</sub> or lower | 1/(2t <sub>INST</sub> ) or lower | DC to 1562.5 kbps | $F_{CH}$ : Oscillation frequency $t_{INST}$ : Instruction cycle #### ■ Serial Function Switching The 8-bit serial I/O and UART cannot be used simultaneously because they use the same pin. For this reason, the serial function switching circuit must be used to switch the 8-bit serial I/O and UART. For more information on the serial function switching circuit, see Section "13.4.7 Serial Switch Register (SSEL)". Selecting the 8-bit serial I/O with this serial function switching circuit enables P30/UCK/SCK to be used as the serial clock I/O pin (SCK) of the serial I/O, and P31/UO/SO to be used as the data output pin (SO). This selection also enables P32/UI/SI to be used as the data input pin (SI). #### Note: This chapter describes pin function switching and the register function, etc., on the assumption that the 8-bit serial I/O is selected with the serial function switching circuit. <sup>\* :</sup> When the highest speed clock of a general mode is selected with the system clock control register (SYCC) (CS1 and CS0 bits of SYCC = 11<sub>B</sub>, 1 instruction cycle = 4/F<sub>CH</sub>) ## 14.2 Configuration of 8-Bit Serial I/O Each 8-bit serial I/O channel consists of the following four blocks: - Shift clock control circuit - Shift clock counter - Serial data register (SDR) - Serial mode register (SMR) #### ■ Block Diagram of 8-bit Serial I/O Figure 14.2-1 Block Diagram of 8-bit Serial I/O #### Shift clock control circuit As a shift clock of the shift clock control circuit, one of three internal clocks and one external clock is selected. Selecting an internal clock enables the shift clock to be output to the SCK pin. Selecting an external clock enables the clock to be input from the SCK pin to act as the shift clock. The shift clock control circuit shifts the SDR in accordance with this shift clock and outputs the shifted-out value to the SO pin. It also captures the data input from the SI pin while shifting it to the SDR. #### Shift clock counter The shift clock counter counts the number of times the SDR was shifted using the shift clock. When 8-bit shift is completed, the counter overflows. When the counter overflows, the serial I/O transfer start bit of the SMR (SST = 0) is cleared and the interrupt request flag bit (SIOF = 1) is set. When serial transfer stops (SST = 0), the counter stops its count. It is cleared when serial transfer is started (SST = 1). #### Serial data register (SDR) The SDR retains transfer data. The data written to the SDR is converted to serial data and output. Serial input is converted to parallel data and stored. #### Serial mode register (SMR) The SMR is a serial I/O control register. It is used to allow and prohibit serial I/O operation, select shift clocks, and set a transfer (shift) direction. It is also used to control interrupts and check interrupt states. #### 8-bit serial I/O interrupt • IRQC: If the interrupt request output is allowed (SMR: SIOE = 1) when the I/O function of the 8-bit serial I/O inputs or outputs 8-bit serial data, a interrupt request (IRQC) is generated. #### 14.3 Pins of 8-Bit Serial I/O #### 8-bit serial I/O pins include P32/UI/SI, P31/UO/SO, and P30/UCK/SCK pins. #### ■ Pins of 8-bit Serial I/O #### ● P32/UI/SI pin The P32/UI/SI pin functions as the general-purpose I/O port (P32). It also functions as the serial data input pin (SI) of the 8-bit serial I/O or as the serial data input pin (UI) of the UART. When using the P32/SI pin as the SI pin, set the P32/UI/SI pin to "input port" with the port direction register (DDR3: bit2 = 0). #### P31/UO/SO pin The P31/UO/SO pin functions as the general-purpose I/O port (P31). It also functions as the serial data output pin (SO) function of the 8-bit serial I/O or as the serial data output pin (UO) function of the UART. When the serial data output is allowed (SMR: SOE = 1), the P31/UO/SO pin automatically becomes an output pin irrespective of the values in the port direction register (bit1 of DDR3) and functions as the SO pin. #### • P30/UCK/SCK pin The P30/UCK/SCK pin functions as the general-purpose I/O port (P30). It also functions as the shift clock I/O pin (SCK) of the 8-bit serial I/O or as the shift clock I/O pin (UCK) of the UART. #### When using the P30/UCK/SCK pin as the shift clock input pin When using the SCK pin as the shift clock input pin, set it to "input port" with the port direction register (DDR3: bit3 = 0) and prohibit shift clock output (SMR: SCKE = 0). In this case, be sure to select the external shift clock (SMR: CKS1, CKS0 = $11_B$ ). #### When using the P30/UCK/SCK pin as the shift clock output pin When the shift clock output is allowed (SMR: SCKE = 1), the P30/UCK/SCK pin automatically becomes an output pin irrespective of the values in the port direction register (DDR3: bit0) and functions as the SCK output pin. In this case, be sure to select an internal shift clock (when SMR: CKS1, CKS0 are not $11_B$ ). ## ■ Block Diagram for 8-bit Serial I/O Pins P30/UCK/SCK PDR ☐ P32/UI/SI Stop mode (SPL = 1) Resource output PDR read Pull-up resistor Resource Resource output available output enable PDR read (At read-modify-write) Internal data bus Pch Output latch 0 PDR write Pin P30/UCK/SCK Nch DDR P31/UO/SO P32/UI/SI DDR write 7/7 Stop mode (SPL=1) PUL read PUL PUL write Figure 14.3-1 Block Diagram for 8-bit Serial I/O Pins #### Note: When "pull-up resistor available" is selected in the pull-up setting register, the pin state in stop mode (SPL = 1) becomes high (pull-up state), not Hi-Z. During the reset, however, pull-up becomes invalid and the pin state becomes Hi-Z. ## 14.4 Registers of 8-Bit Serial I/O ## Figure 14.4-1 shows 8-bit serial I/O registers. #### ■ Registers of 8-bit Serial I/O Figure 14.4-1 8-bit Serial I/O Registers #### Note: When using a bit manipulation instruction, make sure that the SST bit is "0". ## 14.4.1 Serial Mode Register (SMR) The serial mode register (SMR) is used to allow and prohibit 8-bit serial I/O operation, select a shift clock, set a transfer direction, control interrupts, and check interrupt states. #### ■ Serial Mode Register (SMR) Figure 14.4-2 Serial Mode Register (SMR) Table 14.4-1 Explanation of Functions of Each Bit in Serial Mode Register (SMR) (1/2) | Bit name | | Function | | | | |---------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | bit7 | SIOF:<br>Interrupt request flag bit | <ul> <li>When 8-bit serial data is input or output during serial I/O operation, this bit is set to "1". When this bit and the interrupt request allowance bit (SIOE) are "1", an interrupt request is output.</li> <li>Setting this bit to "0" clears it, while setting it to "1" does not affect this bit or implement any changes.</li> </ul> | | | | | bit6 | SIOE:<br>Interrupt request<br>allowance bit | This bit is used to allow and prohibit interrupt request output to the CPU. When this bit and the interrupt request allowance bit (SIOF) are "1", an interrupt request is output. | | | | | bit5 | SCKE:<br>Shift clock output<br>allowance bit | <ul> <li>This bit is used to control shift clock I/O.</li> <li>When this bit is "0", the P30/UCK/SCK pin functions as the shift clock input pin. When "1", it functions as the shift clock output pin.</li> <li>Notes:</li> <li>To use the P30/UCK/SCK pin as the shift clock input pin, it must be set as an input port. Also select the external shift clock with the shift clock selection bits (Set the CKS1 and CKS0 bits to 11<sub>B</sub>).</li> <li>For shift clock output (SCKE bit = 1), select an internal shift clock (do not set the CKS1 and CKS0 bits to 11<sub>B</sub>).</li> <li>Notes:</li> <li>When shift clock output is allowed (when this bit is "1"), the P30/UCK/SCK pin functions as the UCK/SCK output pin irrespective of the general-purpose port (P30) state.</li> <li>When using the P30/UCK/SCK pin as a general-purpose port (P30), set its pin as the shift clock input pin (set this bit to "0").</li> </ul> | | | | | bit4 | SOE:<br>Serial data output<br>allowance bit | When this bit is "0" the P31/UO/SO pin functions as a general-purpose port (P31). When "1", the P31/UO/SO pin functions as the serial data output pin (UO/SO). Note: When serial data output is allowed (when this bit is set to "1"), the P31/UO/SO pin functions as the UO/SO pin irrespective of the general-purpose port (P31) state. | | | | | bit3,<br>bit2 | CKS1, CKS0:<br>Shift clock selection bits | <ul> <li>These bits are used to select three internal shift clocks or one external shift clock.</li> <li>When these bits are not 11<sub>B</sub>, an internal shift clock is selected. When the shift clock output allowance bit (SCKE) is "1", a shift clock is output from the UCK/SCK pin.</li> <li>When these bits are 11<sub>B</sub>, the external clock is selected. When the P30/UCK/SCK pin is set as the shift clock input pin, a shift clock is input from the UCK/SCK pin (when the SCKE bit and bit0 of the DDR3 are "0").</li> </ul> | | | | Table 14.4-1 Explanation of Functions of Each Bit in Serial Mode Register (SMR) (2/2) | Bit name | | Function | | | |----------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | bit1 | BDS:<br>Transfer direction<br>selection bit | This bit is used to select whether to transfer serial data, starting at the lowest bit (LSB first, BDS = 0) or the highest bit (MSB first, BDS = 1). When this bit is set to "0", serial data is transferred, starting at the lowest bit. When it is set to "1", serial data is transferred, starting at the highest bit. Note: If this bit is rewritten after serial data has been written to the SDR to replace higher data with lower data, the data in the SDR becomes invalid. | | | | bit0 | SST:<br>Serial I/O transfer start bit | <ul> <li>This bit is used to control serial I/O transfer start and allowance. It can also be used to judge whether serial I/O transfer terminated.</li> <li>If this bit is set to "1" when the internal shift clock is selected (when the CKS1 and CKS0 bits are not 11<sub>B</sub>), the shift clock counter is cleared and serial I/O transfer is started.</li> <li>If this bit is set to "1" when the external shift clock is selected (when the CKS1 and CKS0 bits are 11<sub>B</sub>), serial I/O transfer is allowed and the shift clock counter is cleared. The transfer side enters the external shift clock input wait state.</li> <li>When serial I/O transfer terminates, this bit is set (cleared) to "0" and the SIOF bit is set to "1".</li> <li>If this bit is set to "0" during serial I/O transfer (SST = 1), serial I/O transfer is suspended. When serial I/O transfer is suspended, it is necessary to reset the SDR of the data output side and restart data input side transfer (clear the shift clock counter).</li> </ul> | | | ## 14.4.2 Serial Data Register (SDR) The serial data register (SDR) retains 8-bit serial I/O transfer data. The SDR functions as a transmission data register at serial output operation. It functions as a reception data register at serial input operation. #### ■ Serial Data Register (SDR) Figure 14.4-3 shows the bit structure of the SDR. Figure 14.4-3 Serial Data Register (SDR) #### At serial output operation The SDR functions as a transmission data register at serial output operation. When serial I/O transfer is started (SMR: SST = 1), the 8-bit serial data written to the SDR is transferred. Transmission data does not remain in the SDR because it is shifted out via serial I/O transfer. #### At serial input operation The SDR functions as a reception data register. When serial I/O transfer is started (SMR: SST = 1), the serially transferred reception data is stored in the SDR. #### • When the serial I/O is in transfer operation When the serial I/O is in transfer operation, do not write data to the SDR. Moreover, note that the read values have no significance. When serial output and serial input are allowed at the same time, serial I/O operation is performed. ## 14.5 Interrupt of 8-Bit Serial I/O #### An 8-bit serial I/O interrupt is caused by completion of 8-bit serial data I/O. #### ■ Interrupt at Serial I/O Operation In the 8-bit serial I/O, serial output operation and serial input operation are performed at the same time. When serial I/O transfer is started, the values in the serial data register (SDR) are input and output on a per bit basis in synchronization with the set shift clock cycle. When the shift clock of the 8th bit rises, the interrupt request flag bit (SMR: SIOF) is set to "1". In this case, when the interrupt request output allowance bit is allowed (SMR: SIOE = 1), the interrupt request (IRQC) for CPU interrupt occurs. Write "0" to the SIOF bit with the interrupt processing routine and clear the interrupt request. When 8-bit serial output is completed, the SIOF bit is set irrespective of the SIOE bit value. If serial I/O transfer stop (SMR: SST = 0) and serial data transfer termination take place at the same time during serial I/O operation, the interrupt request flag bit (SMR: SIOF = 1). If the SIOE bit is allowed $(0 \rightarrow 1)$ , however, the interrupt request occurs immediately. #### ■ 8-bit Serial I/O Interrupt Register and Vector Table Table 14.5-1 8-bit Serial I/O Interrupt Register and Vector Table | Interrupt name | Interrup | t level setting reg | Vector table address | | | |----------------|---------------------------|---------------------|----------------------|-------------------|-------------------| | Interrupt name | Register | Settii | ng bit | Higher | Lower | | IRQC | ILR4 (007E <sub>H</sub> ) | LC1 (bit1) | LC0 (bit0) | FFE2 <sub>H</sub> | FFE3 <sub>H</sub> | For interrupt operation, see Section "3.4.2 Steps in the Interrupt Operation ". ## 14.6 Operations of Serial Output Functions In the 8-bit serial I/O, 8-bit serial output operation synchronized with a shift clock is possible. #### ■ Serial Output Operation Serial output operation is divided into serial output operation using an internal shift clock and serial output operation by using the external shift clock. When serial I/O operation is allowed, serial data is input in the SDR and, at the same time, the contents of the SDR are output to the serial data output pin (SO). Serial output operation via internal shift clock Serial output operation using the internal shift clock requires the settings shown in Figure 14.6-1. Figure 14.6-1 Settings Required for Serial Output Operation using Internal Shift Clock When serial output operation is started, the contents of the SDR are output to the SO pin in synchronization with the falling edge of the selected internal shift clock. In this case, the transfer destination (serial input side) must be in the external shift clock input wait state. #### Serial output operation using external shift clock Serial output operation with the external shift clock requires the settings shown in Figure 14.6-2. Figure 14.6-2 Settings Required for Serial Output Operation using External Shift Clock When serial output operation is allowed, the contents of the SDR are output to the SO pin in synchronization with the falling edge of the external shift clock. When serial operation is completed, immediately reset the SDR, set it again, then allow serial output operation (SMR: SST = 1) to prepare for the output of the next data. When the remote serial input operation (rising edge) is completed and the 8-bit serial I/O enters the idle state (state in which it waits for the output of the next data), set the external shift clock to a high level. Figure 14.6-3 shows 8-bit serial output operation. For LSB first bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 SO pin SDR #7 #6 #5 #4 #3 #2 #1 #0 Serial output data #0 #2 #7 #1 #3 #4 #5 #6 Clear via program Shift clock SIOF bit Transfer start Interrupt request SST bit Automatic clear at transfer end Figure 14.6-3 8-bit Serial Output Operation #### ■ Operation at Serial Output Completion At the rising edge of the shift clock for serial data of the 8th bit, the interrupt request flag bit (SMR: SIOF) is set to "1" and the serial I/O start bit (SMR: SST) is set (cleared) to "0". ## 14.7 Operations of Serial Input Functions In the 8-bit serial I/O, 8-bit serial input operation synchronized with a shift clock is possible. #### ■ Serial Input Operation Serial input operation is divided into serial input operation with an internal shift clock and serial input operation with an external shift clock. When serial I/O operation is allowed, serial data is input in the SDR and, at the same time, the contents of the SDR are output to the serial data output pin (SO). Serial input operation using internal shift clock Serial input operation with the internal shift clock requires the settings shown in Figure 14.7-1. Figure 14.7-1 Settings Required for Serial Input Operation using Internal Shift Clock When serial input operation is started, the value of the serial data input pin (SI) is captured and held in the SDR in synchronization with the rising edge of the selected internal shift clock. In this case, the SDR of the transfer destination (serial output side) must already be set and the transfer destination must be in the external shift clock input wait state. #### Serial input operation using external shift clock Serial input operation with the external shift clock requires the settings shown in Figure 14.7-2. Figure 14.7-2 Settings Required for Serial Input Operation using External Shift Clock When serial input operation is allowed, the value of the SI pin is captured and held in the SDR in synchronization with the rising edge of the external shift clock. When serial input is completed, immediately read the SDR and allow serial input operation (SMR: SST = 1) to prepare for the input of the next data. In this case, when the 8-bit serial I/O is idle (state in which it is waiting for the output of the next data), keep the external shift clock at a "H" level. Figure 14.7-3 shows 8-bit serial input operation. For MSB first bit7 bit6 bit5 bit3 bit2 bit1 bit0 bit4 SI pin SDR #7 #6 #5 #4 #3 #2 #1 #0 Serial input data #7 #6 #5 #4 #3 #0 Shift clock Clear via program SIOF bit Transfer start Interrupt request SST bit Figure 14.7-3 8-bit Serial Input Operation #### ■ Operation at Serial Input Completion At the rising edge of the shift clock for the serial data of the 8th bit, the interrupt request flag bit (SMR: SIOF) is set to "1" and the serial I/O start bit (SMR: SST) is set (cleared) to "0". Automatic clear at transfer end ## 14.8 8-Bit Serial I/O Operation in Each Mode This section describes the operation of the 8-bit serial I/O if the 8-bit serial I/O switches to sleep or stop mode or a stop request is issued when it is in operation. #### ■ When the Internal Shift Clock is Used #### 8-bit serial I/O operation in sleep mode In sleep mode, as shown in Figure 14.8-1, the 8-bit serial I/O continues data transfer without stopping the serial I/O operation. Figure 14.8-1 8-bit Serial I/O Operation in Sleep Mode (Internal Shift Clock) #### 8-bit serial I/O operation in stop mode In stop mode, as shown in Figure 14.8-2, the 8-bit serial I/O stops the serial I/O operation and suspends data transfer. After stop mode has been released, reinitialize the 8-bit serial I/O because operation is resumed halfway. Figure 14.8-2 8-bit Serial I/O Operation in Stop Mode (Internal Shift Clock) • 8-bit serial I/O operation at issuance of stop request during operation As shown in Figure 14.8-3, if operation is stopped (SMR: SST = 0) during data transfer, the 8-bit serial I/O stops data transfer and clears the shift clock counter. For this reason, the transfer destination must also be initialized. If serial output is in operation, set the SDR again before restarting the 8-bit serial I/O. Figure 14.8-3 8-bit Serial I/O Operation at Issuance of Stop Request during Operation(Internal Shift Clock) #### ■ When the External Shift Clock is Used #### 8-bit serial I/O operation in sleep mode In sleep mode, as shown in Figure 14.8-4, the 8-bit serial I/O continues data transfer without stopping the serial I/O operation. SCK input SCK input SST bit SIOF bit SO pin output #0 #1 #2 #3 #4 #5 #6 #7 Sleep mode release via IRQC Figure 14.8-4 8-bit Serial I/O Operation in Sleep Mode (External Shift Clock) #### 8-bit serial I/O operation in stop mode In stop mode, as shown in Figure 14.8-5, the 8-bit serial I/O stops the serial I/O operation and suspends data transfer. After stop mode has been released, a transfer destination error occurs because operation is resumed halfway. In this case, initialize the 8-bit serial I/O. Figure 14.8-5 8-bit Serial I/O Operation in Stop Mode (External Shift Clock) #### • 8-bit serial I/O operation at issuance of stop request during operation As shown in Figure 14.8-6, if operation is stopped (SMR: SST = 0) during data transfer, the 8-bit serial I/O stops data transfer and clears the shift clock counter. For this reason, the transfer destination must also be initialized. If serial output is in operation, set the SDR again before restarting the 8-bit serial I/O. In this case, when the external clock is input, the SO pin output changes. Figure 14.8-6 8-bit Serial I/O Operation at Issuance of Stop Request during Operation (External Shift Clock) ## 14.9 Notes on Using 8-Bit Serial I/O This section provides notes on using the 8-bit serial I/O. ## ■ Notes on Using 8-bit Serial I/O #### Error at serial transfer start The time at which serial I/O transfer is started with a serial transfer program (SMR: SST = 1) is asynchronous with the time when the falling edge (output) or rising (input) edge of a shift clock occurs. For this reason, the time that lasts until the first serial data is input or output is delayed by a maximum of one cycle of the set shift clock. #### Malfunction due to noise If external noise causes an extra pulse (pulse exceeding the hysteresis width) to be placed on a shift clock during serial data transfer, the 8-bit serial I/O may malfunction. #### Notes on setting via program - Write data to the serial mode register (SMR) and serial data register (SDR) only when the 8-bit serial I/O is stopped (SMR: SST = 0). - When starting or allowing serial I/O transfer (SMR: SST=1), do not change other bits of the SMR. - If MSB first is set when a shift clock is used in external shift clock input, the highest bit level is output as the SO pin output level. If LSB first is set, the lowest bit level is output as the SO pin output level. MSB first and LSB first are set when the external shift clock is input. In this case, however, serial data output must be allowed (SMR: SOE = 1) even if serial I/O transfer is stopped (SMR: SST = 0). - If serial I/O transfer stop (SMR: SST = 0) and serial data transfer termination take place at the same time during serial I/O operation, the interrupt request flag bit (SMR: SIOF) is not set to "1". - If the SIOF bit is set to "1" and the interrupt request output allowance bit is enabled (SMR: SIOE = 1), control cannot return from interrupt processing. Be sure to clear the SIOF bit. #### Shift clock idle state The external shift clock must maintain the "H" level during the wait time between one 8-bit data transfer and another (idle state). When the internal shift clock is selected (SMR: CKS1, CKS0 = not $11_B$ ) and the P30/UCK/SCK pin is used as the shift clock output pin (SMR: SCKE = 1), data is output at the "H" level in the idle state. Figure 14.9-1 shows the shift clock idle state. Figure 14.9-1 Shift Clock Idle State ## 14.10 Example of 8-Bit Serial I/O Connection This section provides an example of mutual connection between 8-bit serial I/Os of MB89202/F202RA series for bidirectional serial I/O operation. ## ■ When Bidirectional Serial I/O Operation is Performed Figure 14.10-1 Example of 8-bit Serial I/O Connection (Interface between MB89202/F202RA Series) Figure 14.10-2 Bidirectional Serial I/O Operation ## 14.11 Program Example for 8-Bit Serial I/O #### This section provides program example for 8-bit serial I/O. #### ■ Program Example for 8-bit Serial Output #### Processing Specifications - The 8-bit serial output program outputs 8-bit serial data (55<sub>H</sub>) from the SO pin of the 8-bit serial I/O. When serial I/O transfer terminates, an interrupt occurs. - The program resets transfer data with the interrupt processing routine and outputs it continuously. - The program operates in accordance with the internal shift clock. This clock is output from the SCK pin. - If the shift clock is $32t_{INST}$ when the maximum gear speed (1 instruction cycle = $4/F_{CH}$ ) at the 12.5-MHz oscillation ( $F_{CH}$ ), the transfer rate and interrupt cycle are as follows: Transfer rate = 12.5 MHz/4/32 = 97.7 kbps, interrupt cycle = $8 \times 32 \times 4/10$ MHz = 81.92 µs #### Coding example | SMR | EQU | 0039H | ; | Address of serial mode register | |-------|------|-----------------|---|-----------------------------------------------------------| | SDR | EQU | 003AH | ; | Address of serial data register | | SSEL | EQU | 003BH | ; | Address of serial/UART selection register | | SIOF | EQU | SMR:7 | ; | Defines the interrupt request flag bit. | | SST | EQU | SMR:0 | ; | Defines the serial I/O transfer start bit. | | ILR4 | EQU | 007EH | ; | Address of interrupt request setting register 4 | | INT_V | DSEG | ABS | ; | [DATA SEGMENT] | | | ORG | 0FFE2H | | | | IRQC | DW | WARI | ; | Sets an interrupt vector. | | INT_V | ENDS | | | | | ; | Mai | in program | | | | | CSEG | | ; | [CODE SEGMENT] | | | | | ; | The stack pointer (SP), etc., are already initialized. | | | : | | | | | | CLRI | | ; | Disables interrupts. | | | CLRB | SST | ; | Stops serial I/O transfer. | | | MOV | ILR4,#11111101B | ; | Sets the interrupt level to 1. | | | MOV | SDR,#55H | ; | Sets transfer data (55H). | | | MOV | SMR,#01111000B | ; | Clears the interrupt request flag, allows the interrupt | | | | | | request output, shift clock output (SCK), and serial data | | | | | | output (SO), selects 32tINST, and sets LSB first. | | | MOV | SSEL,#00000001B | ; | Selects the 8-bit serial I/O. | | | SETB | SST | ; | Starts serial I/O transfer. | | | SETI | | ; | Enables interrupts. | | | : | | | | ``` ;-----Interrupt processing routine----- WARI CLRB SIOF ; Clears the interrupt request flag. PUSHW A XCHW A,T ; Saves A and T. PUSHW Α MOV SDR,#55H ; Resets transfer data (55<sub>H</sub>). SETB SST ; Starts serial I/O transfer. : User processing POPW Α XCHW A,T ; Returns A and T. POPW Α RETI ENDS END ``` #### ■ Program Example for 8-bit Serial Input #### Processing specifications - The 8-bit serial input program inputs 8-bit serial data from the SI pin of the 8-bit serial I/O. When serial I/O transfer terminates, an interrupt occurs. - The program reads transfer data with the interrupt processing routine and inputs it continuously. - The program uses the external shift clock to be input from the SCK pin. #### Coding example | DDR3 | EQU | 000DH | ; | Address of data direction register 3 | |-------|------|-----------------|---|-------------------------------------------------------| | SMR | EQU | 0039H | ; | Address of serial mode register | | SDR | EQU | 003AH | ; | Address of serial data register | | SSEL | EQU | 003BH | ; | Address of serial/UART selection register | | SIOF | EQU | SMR:7 | ; | Defines the interrupt request flag bit. | | SST | EQU | SMR:0 | ; | Defines the serial I/O transfer start bit. | | ILR4 | EQU | 007EH | ; | Address of interrupt request setting register 4 | | INT_V | DSEG | ABS | ; | [DATA SEGMENT] | | | ORG | 0FFE2H | | | | IRQC | DW | WARI | ; | Sets an interrupt vector. | | INT_V | ENDS | | | | | ; | Main | program | | | | | CSEG | | ; | [CODE SEGMENT] | | | | | ; | The stack pointer (SP), etc., is already initialized. | | | : | | | | | | MOV | DDR3,#00000000B | ; | Sets the P30/SCK and P32/SI pins to input. | | | CLRI | | ; | Disables interrupts. | | | CLRB | SST | ; | Stops serial I/O transfer. | | | MOV | ILR4,#11111101B | ; | Sets the interrupt level to 1. | | | | | | | MOV SMR,#01001100B ; Clears the interrupt request flag, allows the interrupt request output, sets shift clock input (SCK), prohibits serial data output (SO), selects the external shift clock, and sets LSB first. MOV SSEL,#00000001B; Selects the 8-bit serial I/O. **SETB** SST ; Allows serial I/O transfer. **SETI** ; Enables interrupts. -----Interrupt processing routine--WARI **CLRB** ; Clears the interrupt request flag. **PUSHW** Α **XCHW** A,T **PUSHW** MOV A,SDR ; Reads transfer data. **SETB** SST ; Allows serial I/O transfer. User processing POPW Α **XCHW** A,T **POPW** Α **RETI ENDS END** # CHAPTER 15 BUZZER OUTPUT This chapter describes the functions and operation of the buzzer output. - 15.1 Overview of the Buzzer Output - 15.2 Configuration of the Buzzer Output - 15.3 Pin of the Buzzer Output - 15.4 Buzzer Register (BZCR) - 15.5 Program Example for Buzzer Output ## 15.1 Overview of the Buzzer Output For the buzzer output, four kinds of output frequencies (square waves) can be selected. The buzzer output may be used for the confirmation tone of key input and other tones. #### **■** Buzzer Output Function The buzzer output function is a function for outputting a signal (square wave) used for tones such as a confirmation tone. For the buzzer output, it is selectable whether to output one of four output frequencies or to disable the output. As the buzzer output, four kinds of divided-frequency outputs are supplied from the time-base timer. #### Note: The time-base timer supplies clock for the buzzer output. Therefore, buzzer output will be affected when time-base timer is cleared. Table 15.1-1 lists the four kinds of output frequencies (square waves) specifiable for the buzzer output. **Table 15.1-1 Output Frequencies** | Clock supplier | Buzzer output | Square wave output (at 12.5 MHz) | | |-----------------|----------------------------------|----------------------------------------------|--| | | $2^{13}/F_{CH}$ | $F_{CH}/2^{13} (1.526 \text{ kHz})$ | | | time-base timer | $2^{12}/F_{CH}$ | F <sub>CH</sub> /2 <sup>12</sup> (3.052 kHz) | | | time-base timer | 2 <sup>11</sup> /F <sub>CH</sub> | F <sub>CH</sub> /2 <sup>11</sup> (6.104 kHz) | | | | 2 <sup>10</sup> /F <sub>CH</sub> | F <sub>CH</sub> /2 <sup>10</sup> (12.21 kHz) | | F<sub>CH</sub>: Oscillation frequency #### Note: Calculation example of an output frequency If time-base timer output $F_{CH}/2^{10}$ is selected in the buzzer register (BZCR) (BZ2=1, BZ1=0, and BZ0=0) and the oscillation ( $F_{CH}$ ) is 12.5 MHz, the output frequency being output from the BZ pin is calculated as follows: Output frequency = $$F_{CH}/2^{10}$$ = 12.5 MHz/1024 $\stackrel{.}{=}$ 12.21 kHz ## 15.2 Configuration of the Buzzer Output The buzzer output consists of the following two blocks: - Buzzer output selector - Buzzer register (BZCR) #### ■ Block Diagram of the Buzzer Output Figure 15.2-1 Block Diagram of Buzzer Output #### Buzzer output selector The buzzer output selector is a circuit for selecting one of the four frequencies (square waves) output from the time-base timer. The buzzer register (BZCR) sets it. #### Buzzer register (BZCR) The buzzer register (BZCR) is a register for setting the buzzer output frequency and enable the buzzer output. When the BZCR register sets an output frequency (other than $000_B$ ), the buzzer output is enabled so that the P37/BZ/PPG pin automatically becomes the buzzer output (BZ) pin. Even if the PPG pin has been enabled, the BZ pin has higher priority. ## 15.3 Pin of the Buzzer Output #### The pin related to the buzzer output is P37/BZ/PPG. #### ■ P37/BZ/PPG Pin The P37/BZ/PPG pin works as a general-purpose I/O (P37) pin, output pin for the buzzer output (BZ), or output pin for the 12-bit PPG (PPG). #### BZ pin The BZ pin outputs the square wave for the buzzer of the frequency having been specified for the BZ pin. When a buzzer output frequency is specified (other than BZCR:BZ2,BZ1,BZ0= $000_B$ ), the P37/BZ/PPG pin automatically works as the BZ pin regardless of the value of output latch. Even if the PPG output has been enabled, it works as the BZ pin that has higher priority. #### ■ Block Diagram of the Pin Related to the Buzzer Output Figure 15.3-1 Block Diagram of Pin Related to Buzzer Output #### Note: If pull-up resistor supported is specified by the pull-up setting register, the state of the pin in stop mode (SPL=1) is not Hi-Z but "H" level (pull-up state). During a reset, however, the pull-up is disabled and the state is Hi-Z. ## 15.4 Buzzer Register (BZCR) The buzzer register (BZCR) is used to select an output frequency of the buzzer and also serves as the buzzer output enable. #### **■** Buzzer Register (BZCR) Figure 15.4-1 Buzzer Register (BZCR) Table 15.4-1 Functions of Each Bit in Buzzer Register (BZCR) | | Bit name | Function | | | |--------------------|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | bit7<br>to<br>bit3 | Unused bits | <ul><li> Undefined at read</li><li> No effect on the operation at write</li></ul> | | | | bit2<br>to<br>bit0 | BZ2, BZ1, and BZ0:<br>Buzzer selection bits | <ul> <li>Select a buzzer output and enable the output.</li> <li>If 000<sub>B</sub> is set to these bits, the buzzer output is disabled and the pin works as a general-purpose port (P37) or as the 12-bit PPG output (PPG). With the exception of 000<sub>B</sub>, the pin becomes the buzzer pin and outputs a square wave. Even if the pin has been functioning as the 12-bit PPG output, setting a value other than 000<sub>B</sub> causes the pin to work as the BZ pin prior to its operation as the PPG pin. For the buzzer output, four kinds of time-base timer divided cycle outputs are supplied.</li> </ul> | | | # 15.5 Program Example for Buzzer Output This section shows an program example for buzzer output. ## ■ Program Example for Buzzer Output #### Processing specification Suppose that the buzzer output of 3.052 kHz is output to the BZ pin and then the buzzer output is cut off. If $2^{12}/F_{CH}$ is selected when the oscillation ( $F_{CH}$ ) is 12.5 MHz, the buzzer output frequency is calculated as follows: Buzzer output frequency: $12.5 \text{ MHz}/2^{12} = 12.5 \text{ MHz}/4096 = 3.052 \text{ kHz}$ #### Coding example ## CHAPTER 15 BUZZER OUTPUT # **CHAPTER 16** # WILD REGISTER FUNCTION This chapter describes the functions and operation of the wild registers. - 16.1 Overview of the Wild Register Function - 16.2 Configuration of the Wild Register Function - 16.3 Registers of the Wild Register Function - 16.4 Operations of the Wild Register Functions ## 16.1 Overview of the Wild Register Function The wild register function is a function for patching the faulty part of a program by setting the address and the correct data in the incorporated registers. Up to two bytes of data correction is possible. #### ■ Wild Register Function The wild register function assigns an address in the ROM area of the microcontroller and replaces the existing data corresponding to the address, with new data. For example, if an error exists in a program, setting the address of the faulty part and correction data to the register can correct the faulty data. #### ■ Wild Register Applicable Addresses The address area where the wild register function can apply varies slightly with the models. Table 16.1-1 shows the wild register applicable addresses for each model. **Table 16.1-1 Wild Register Applicable Addresses** | Model name | ROM area | |--------------|----------------------------------------| | MB89V201 | 8000 <sub>H</sub> to FFFF <sub>H</sub> | | MB89202/F202 | C000 <sub>H</sub> to FFFF <sub>H</sub> | #### Note: The wild register function cannot be debugged with a tool. Perform the operation check of the wild register on the actual microcontroller, MB89202/F202/F202RA. ## 16.2 Configuration of the Wild Register Function The wild register function consists of the following two blocks: ## Memory area part - Data setting register (WRDR) - Higher address set register (WRARH) - Lower address set register (WRARL) #### **Control circuit part** ### ■ Block Diagram of the Wild Register Function Figure 16.2-1 Block Diagram of Wild Register Function #### Memory area part This part consists of the data setting register, higher address set register ("H" address), and lower address set register ("L" address). Set the address and data to be replaced by the wild register. The MB89202/F202RA series incorporates two bytes for each register. #### Control circuit part This part compares the data held in the address set registers and the actual data on the address bus. If it detects a match, it sets the data in the data setting register to the data bus. The control circuit part can control the operation by the address comparison EN register. # 16.3 Registers of the Wild Register Function ## Figure 16.3-1 shows the registers related to the wild register function. ## ■ Registers Related to the Wild Register Function Figure 16.3-1 Registers Related to Wild Register Function | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | |-------------------|--------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-----------------------------------------| | | | | | | | | | | 1 | | 0042 <sub>H</sub> | RD07<br>R/W | RD06<br>R/W | RD05<br>R/W | RD04<br>R/W | RD03<br>R/W | RD02<br>R/W | RD01<br>R/W | RD00<br>R/W | XXXXXXXX | | 0045 <sub>H</sub> | 17/ 77 | 17,44 | 17/ / / | 17/77 | 17/ 77 | 17/ 77 | 17/77 | 17/ / / | | | WRARH0,WR | ARH1 (Hig | her addre | ss set reg | jister) | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0040 <sub>H</sub> | RA15 | RA14 | RA13 | RA12 | RA11 | RA10 | RA09 | RA08 | xxxxxxx | | 0043 <sub>H</sub> | R/W | | WRARL0,WRA | ARL1 (Low | er addres | s set regis | ster) | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0041 <sub>H</sub> | RA07 | RA06 | RA05 | RA04 | RA03 | RA02 | RA01 | RA00 | xxxxxxxx | | 0044 <sub>H</sub> | R/W ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | WREN (Addre | ess compai | rison FN ı | register) | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0046 <sub>H</sub> | | _ | _ | _ | | | EN01 | EN00 | 00 <sub>R</sub> | | | | | | | | | R/W | R/W | В | | WROR (Data | test set rec | gister) | | | | | | | | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | | 0047 <sub>H</sub> | | | _ | | | _ | RESV1 | RESV0 | 00 <sub>B</sub> | | 0041 H | | | | | | | R/W | R/W | I00B | | | | | | | | | 1 1 / V V | 17,44 | | | R/W : | Readable | and Writa | able | | | | | | | | | Unused | | | | | | | | | # 16.3.1 Data Setting Registers (WRDR0 and WRDR1) The data setting registers (WRDR0 and WRDR1) are registers where the correct data used by the wild register function is set. ## ■ Data Setting Register (WRDR) Figure 16.3-2 Data Setting Register (WRDR) | | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | |-------|-------------------|-----------|------|------|------|------|------|------|------|---------------| | WRDR0 | 0042 <sub>H</sub> | RD07 | RD06 | RD05 | RD04 | RD03 | RD02 | RD01 | RD00 | XXXXXXXX | | | | R/W _ | | | | | | | | | | | | | | WRDR1 | 0045 <sub>H</sub> | RD07 | RD06 | RD05 | RD04 | RD03 | RD02 | RD01 | RD00 | XXXXXXXX | | | | R/W | | R/W | : Readable | and Write | able | | | | | | | | | X | : Undefined | | anie | | | | | | | | Table 16.3-1 Functions of Data Setting Register (WRDR) | | Wild register number | Register name | Function | |---|----------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------| | | 0 | WRDR0 | 1-byte registers that store the data at the address assigned by WRARL | | ĺ | 1 | WRDR1 | and WRARH. The data will be effective at the addresses (WRARL and WRARH) corresponding to the individual wild register numbers. | #### Note: The WRDR register is readable, only when the WREN register (address comparison EN register) is set. # 16.3.2 Higher Address Set Registers (WRARH0 and WRARH1) The higher address set registers (WRARH0 and WRARH1) are registers where the higher byte of addresses to be corrected by the wild register function are set. ## **■** Higher Address Set Register (WRARH) Figure 16.3-3 Higher Address Set Register (WRARH) | Address | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | Initial value | |--------------------------------|------|------|------|------|------|------|------|------|---------------| | WRARHO 0040 H | RA15 | RA14 | RA13 | RA12 | RA11 | RA10 | RA09 | RA08 | XXXXXXXX B | | | R/W | | | | | | | | | | | | | WRARH1 0043 H | RA15 | RA14 | RA13 | RA12 | RA11 | RA10 | RA09 | RA08 | xxxxxxxx | | | R/W | | R/W : Readable<br>X : Undefine | | able | | | | | | | | Table 16.3-2 Functions of Higher Address Set Register (WRARH) | Wild register number | Register name | Function | |----------------------|---------------|---------------------------------------------------------------------------------------------| | 0 | WRARH0 | 1-byte registers that specify the higher addresses of memory being | | 1 | WRARH1 | assigned. They specify the addresses corresponding to the individual wild register numbers. | # 16.3.3 Lower Address Set Registers (WRARL0 and WRARL1) The lower address set registers (WRARL0 and WRARL1) are registers where the lower byte of addresses to be corrected by the wild register function are set. #### ■ Lower Address Set Register (WRARL) Figure 16.3-4 Lower Address Set Register (WRARL) X : Undefined Table 16.3-3 Functions of Lower Address Set Register (WRARL) | Wild register number | Register name | Function | |----------------------|---------------|---------------------------------------------------------------------------------------------| | 0 | WRARL0 | 1-byte registers that specify the lower addresses of memory being | | 1 | WRARL1 | assigned. They specify the addresses corresponding to the individual wild register numbers. | # 16.3.4 Address Comparison EN Register (WREN) The address comparison EN register (WREN) is a register that enables the operation of wild register function for the individual wild register numbers. ## ■ Address Comparison EN Register (WREN) Figure 16.3-5 Address Comparison EN Register (WREN) Table 16.3-4 Explanation of Functions of Each Bit in Address Comparison EN Register (WREN) | | Bit name | Function | | | | | |--------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | bit7<br>to<br>bit2 | Unused bits | Undefined at read No effect to the operation at write | | | | | | bit1 | EN01 | When this bit is "0", the corresponding wild register function does not work. When this bit is "1", the wild register function is enabled. If there is a match with the address held in WRARH1 and WRARL1, the value of WRDR1, instead of ROM, is output to the internal bus. | | | | | | bit0 | EN00 | When this bit is "0", the corresponding wild register function does not work. When this bit is "1", the wild register function is enabled. If there is a match with the address held in WRARH0 and WRARL0, the value of WRDR0, instead of ROM, is output to the internal bus. | | | | | # 16.3.5 Data Test Set Register (WROR) A test register. Do not access this register. # 16.4 Operations of the Wild Register Functions This section describes the operation order of the wild register. ### ■ Operation Order of the Wild Register Function Table 16.4-1 describes the operation order of the wild register. In the operation example column, it corrects data at address $FC36_H$ , from $FF_H$ to $B5_H$ . Table 16.4-1 Operation Order of Wild Register | | Operation | Operation example | |---|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------| | 1 | Set an address of the wild register correspondence area to the address set register. | Address: FC36 <sub>H</sub> /data: FF <sub>H</sub><br>WRARL0=36 <sub>H</sub><br>WRARH0=FC <sub>H</sub> | | 2 | Set the correction data to the data setting register. | WRDR0=B5 <sub>H</sub> | | 3 | Set "1" to the address comparison EN00 bit. | WREN=01 <sub>H</sub> | | 4 | The wild register works at the time of address matching. | When address = $FC36_H$ is accessed<br>$\downarrow$ $Data = B5_H$ | #### ■ Wild Register Addresses List Table 16.4-2 lists the addresses corresponding to the wild register numbers. Table 16.4-2 Wild Register Addresses List | | Higher address | | Lower ac | ldress | Data | | | |---|-----------------------|------------------|---------------|------------------|---------------|------------------|--| | | Register name Address | | Register name | Address | Register name | Address | | | 1 | WRARH0 | 040 <sub>H</sub> | WRARL0 | 041 <sub>H</sub> | WRDR0 | 042 <sub>H</sub> | | | 2 | WRARH1 | 043 <sub>H</sub> | WRARL1 | 044 <sub>H</sub> | WRDR1 | 045 <sub>H</sub> | | # CHAPTER 17 # FLASH MEMORY This chapter describes the functions and operation of the 128K-bit flash memory. The following three methods are available for writing data to and erasing data from the flash memory: - 1. Parallel programmer - 2. Writing/erasing data using a serial programmer - 3. Executing programs to write/erase data This chapter explains "Executing programs to write/ erase data". Note: A user must create a serial programmer for writing. - 17.1 Overview of Flash Memory - 17.2 Flash Memory Control Status Register (FMCS) - 17.3 Starting the Flash Memory Automatic Algorithm - 17.4 Confirming the Automatic Algorithm Execution State - 17.5 Detailed Explanation of Writing to Erasing Flash Memory - 17.6 Flash Security Feature - 17.7 Notes on using Flash Memory ## 17.1 Overview of Flash Memory The 128K-bit flash memory is mapped to the $\rm C000_H$ to $\rm FFFF_H$ bank in the CPU memory map. The functions of the flash memory interface circuit enable read-access and program-access from the CPU in the same way as mask ROM. Instructions from the CPU can be used via the flash memory interface circuit to write data to and erase data from the flash memory. Internal CPU control therefore enables rewriting of the flash memory while it is mounted. As a result, improvements in programs and data can be performed efficiently. #### **■ Flash Memory Features** - 16 Kbyte × 8-bit configuration - Use of automatic program algorithm (Embedded Algorthm) - Detection of completion of writing/erasing using data polling or toggle bit functions - Detection of completion of writing/erasing using CPU interrupts - Compatible with JEDEC standard commands - Minimum of 10000 write / erase operations (MB89F202/F202RA) ### ■ High voltage supply on RST pin (applicable to MB89F202RA only) During writing data to or erasing all data in flash memory, a typical +10V D.C. voltage should be applied at the RST pin. After applying the high voltage, wait for 10ms before writing data or erasing all data in flash memory. And this applied voltage should be kept at the RST pin until data writing or erasing has been completed. #### ■ Writing to/Erasing Flash Memory The flash memory cannot be written to and read at the same time. That is, when data is written to or erased data from the flash memory, the program in the flash memory must first be copied to RAM. The entire process is then executed in RAM so that data is simply written to the flash memory. This eliminates the need for the program to access the flash memory from the flash memory itself. #### **■** Flash Memory Register Compatible with JEDEC standard commands | Bit No. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-------------------|-------|--------|-------|------|------|------|------|------| | 0079 <sub>H</sub> | INTE | RDYINT | WE | RDY | - | - | - | - | | Read/write | (R/W) | (R/W) | (R/W) | (R) | (-) | (-) | (-) | (-) | | Initial value | (0) | (0) | (0) | (X) | (-) | (-) | (-) | (-) | ## 17.2 Flash Memory Control Status Register (FMCS) The flash memory control status register (FMCS), together with the flash memory interface circuit, is used to write data to and erase data from the flash memory. #### ■ Flash Memory Control Status Register (FMCS) Figure 17.2-1 Flash Memory Control Status Register (FMCS) Table 17.2-1 Explanation of Functions of Each Bit in the Flash Memory Control Status Register (FMCS) | | Bit name | Description | |--------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | bit7 | INTE: Causing an interrupt to the CPU to be generated bit | Bit causing an interrupt (IRQB) to the CPU to be generated when writing into or erasing from flash memory is completed. An interrupt (IRQB) to the CPU is generated when both the INTE bit and RDYINT bit are "1". If the INTE bit is "0", no interrupt is generated. | | bit6 | RDYINT:<br>Flash memory<br>operation state<br>indication bit | Bit for indicating operation status of flash memory. This bit is set to "1" when writing into or erasing from flash memory is completed. After data has been written into or erased from flash memory and this bit has been set to "1", subsequent data can be written into or erased from flash memory. Writing "0" clears this bit with "0", while if "1" is written into this bit, it is ignored. This bit is set to "1" upon the termination of the flash memory automatic algorithm (see Section "17.3 Starting the Flash Memory Automatic Algorithm ". The read modifier write (RMW) command always reads "1" from this bit. | | bit5 | WE:<br>Write enable bit | Bit for write-enabling flash memory areas. When this bit is set to "1", a write instruction performed after a command sequence for a section from C000 <sub>H</sub> to FFFF <sub>H</sub> (see Section "17.3 Starting the Flash Memory Automatic Algorithm") is issued writes data into a flash memory area. When this bit is set to "0", no write/erase signals are generated. This bit is used to start a command for writing data into or erasing data from flash memory. It is recommended that this bit be set to "0" to prevent data from being incorrectly written into flash memory, whenever there is no data to be written or erased. | | bit4 | RDY:<br>ReaDY bit | Bit for status checking for writing data into or erasing data from flash memory. No data can be written into or erased from flash memory while this bit is "0". However, a read command, reset command, and suspend commands such as the sector erase suspend command can be accepted while this bit is "0". | | bit3<br>to<br>bit0 | Unused bits | Reading / Writing for these bits have no effect. | #### Note: The RDYINT and RDY bits cannot be changed at the same time. Create a program so that decisions are made using one or the other of these bits. # 17.3 Starting the Flash Memory Automatic Algorithm Four types of commands are available for starting the flash memory automatic algorithm: Read/Reset, Write, and Chip Erase. #### **■** Command Sequence Table Table 17.3-1 lists the commands used for flash memory write/erase. **Table 17.3-1 Command Sequence Table** | Command sequence | Bus<br>write<br>access | 1st bus | | 2nd bus | | 3rd bus | | 4th bus<br>write c | | 5th bus | | 6th bus | | |------------------|------------------------|---------|------|---------|------|---------|------|--------------------|------|---------|------|---------|------| | | accc33 | Address | Data | Address | Data | Address | Data | Address | Data | Address | Data | Address | Data | | Read/Reset | 1 | XXXX | F0 | - | - | - | - | - | - | - | - | - | - | | (*) | 4 | FAAA | AA | F554 | 55 | FAAA | F0 | RA | RD | - | - | - | - | | Write program | 4 | FAAA | AA | F554 | 55 | FAAA | A0 | PA | PD | - | - | - | - | | Chip Erase | 6 | FAAA | AA | F554 | 55 | FAAA | 80 | FAAA | AA | F554 | 55 | FAAA | 10 | <sup>\*:</sup> Both of the two types of Read/Reset commands can reset the flash memory to read mode. #### **Notes:** - The addresses shown in the table are those on the CPU memory map. All addresses and data are represented in hexadecimal notation. The letter X indicates an appropriate value. - RA: Read address - PA: Write address. - RD: Read data - PD: Write data. - The flash memory can only accept the command sequences mentioned on the above table (Read/Reset, Write program, Chip Erase), other command sequences are strictly prohibited to be sent to the flash memory or else the flash memory may become malfunction. # 17.4 Confirming the Automatic Algorithm Execution State Because the write/erase flow of the flash memory is controlled using the automatic algorithm, the flash memory has hardware for posting its internal operating state and completion of operation. This automatic algorithm enables confirmation of the operating state of the built-in flash memory using the following hardware sequence flags. ### ■ Hardware Sequence Flags The hardware sequence flags are configured from the five-bit output of DQ7, DQ6, DQ5, and DQ2. The functions of these bits are those of the data polling flag (DQ7), toggle bit flag (DQ6), timing limit exceeded flag (DQ5), and toggle bit2 flag (DQ2). The hardware sequence flags can therefore be used to confirm that writing or chip sector erase has been completed or that erase code write is valid. The hardware sequence flags can be accessed by read-accessing the addresses of the target sectors in the flash memory after setting of the command sequence (see Table 17.3-1 in Section "17.3 Starting the Flash Memory Automatic Algorithm"). Table 17.4-1 lists the bit assignments of the hardware sequence flags. Table 17.4-1 Bit Assignments of Hardware Sequence Flags | | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------------------------|------|------|------|------|------|------|------|------| | Hardware sequence flag | DQ7 | DQ6 | DQ5 | - | - | DQ2 | - | - | To determine whether automatic writing or chip sector erase is being executed, the hardware sequence flags can be checked or the status can be determined from the RDY bit of the flash memory control status register (FMCS) that indicates whether writing has been completed. After writing/erasing has terminated, the state returns to the read/reset state. When creating a program, use one of the flags to confirm that automatic writing/erasing has terminated. Then, perform the next processing operation, such as data read. In addition, the hardware sequence flags can be used to confirm whether the second or subsequent sector erase code write is valid. The following sections describe each hardware sequence flag separately. Table 17.4-2 lists the functions of the hardware sequence flags. **Table 17.4-2 Hardware Sequence Flag Functions** | | DQ7 | DQ6 | DQ5 | DQ2 | | |----------------|-----------------------------|----------------|--------|-----|--------| | Executing | Automatic writing operation | DQ7 | Toggle | 0 | 1 | | | Automatic erasing operation | 0 | Toggle | 0 | Toggle | | Exceeding | Automatic writing operation | <del>DQ7</del> | Toggle | 1 | 1 | | the time limit | Automatic erasing operation | 0 | Toggle | 1 | Toggle | ## 17.4.1 Data Polling Flag (DQ7) The data polling flag uses the data polling function to post that the automatic algorithm is being executed or has terminated #### ■ Write Read-access during execution of the automatic write algorithm causes the flash memory to output the opposite data of bit7 last written, regardless of the value at the address specified by the address signal. Read-access at the end of the automatic write algorithm causes the flash memory to output bit7 of the read value of the address specified by the address signal. #### **■** Automatic Erasing Read-access during execution of the automatic erasing algorithm causes the flash memory to output "0", regardless of the value at the address specified by the address signal. After the automatic erasing algorithm is executed, "1" is output. #### Note: When the automatic algorithm comes to the end of its operation, bit7 (data polling) changes its state asynchronously during a read operation. This means that flash memory sends data about the operation state to bit7 and will then send out fixed data. When flash memory ends the automatic algorithm or even if bit7 is outputting fixed data, the values of the other bits are still undetermined. Fixed data in the other bits can be read by successively executing read operations. # 17.4.2 Toggle Bit Flag (DQ6) Like the data polling flag, the toggle bit flag uses the toggle bit function to post that the automatic algorithm is being executed or has terminated. #### ■ Automatic Write/Erase Making successive read accesses while the automatic writing/erasing algorithm is being performed toggles flash memory and makes it output 1 and then 0, in turn, regardless of the specified address. Making successive read accesses when the automatic writing/erasing algorithm ends makes flash memory to stop bit6 toggle and outputs the value of bit6 (DATA:6) corresponding to the value read from the specified address. The toggle bit becomes effective after the last write cycle in each command sequence. ## 17.4.3 Timing Limit Exceeded Flag (DQ5) The timing limit exceeded flag is used to post that execution of the automatic algorithm has exceeded the time (internal pulse count) prescribed in the flash memory. #### ■ Automatic Write/Erase Bit5 indicates that execution of the automatic algorithm exceeded the time (internal pulse count) specified in flash memory. For an excess, bit5 outputs 1. Thus, if this bit outputs 1 while the automatic algorithm is operating, data writing or data erasing failed. Bit5 indicates a failure when an attempt is made to write data into a non-blank area without erasing any data. In the case of such a failure, fixed data cannot be read from bit7 (data polling) and bit6 (toggle bit) remains unchanged (toggled). If the time limit is exceeded while there is a failure, "1" is set in bit5. In this case, note that the setting of bit5 to "1" does not indicate a flash memory failure but the incorrect use of flash memory. If bit5 is set to "1" as described above, execute a reset command. # 17.4.4 Toggle Bit-2 Flag (DQ2) The toggle bit-2 flag (DQ2) is used to detect that flash memory is performing an automatic erase operation, together with the toggle bit. #### **■** Automatic Write/Erase Making successive read accesses while the automatic erasing algorithm is being performed toggles flash memory and makes it output 1 and then 0, in turn, regardless of the specified address. Making successive read accesses while the automatic writing algorithm is being performed toggles flash memory and makes it output 1 regardless of the specified address. Making successive read accesses when the automatic writing/erasing algorithm ends makes flash memory to stop bit2 toggle and outputs the value of bit2 (DATA:6) corresponding to the value read from the specified address. The toggle bit becomes effective after the last write cycle in each command sequence. ## 17.5 Detailed Explanation of Writing to Erasing Flash Memory This section describes each operation procedure of flash memory Read/Reset, Write, Chip Erase, when a command that starts the automatic algorithm is issued. #### ■ Detailed Explanation of Flash Memory Write/Erase The flash memory executes the automatic algorithm by issuing a command sequence (see Table 17.3-1 in Section "17.3 Starting the Flash Memory Automatic Algorithm "for a write cycle to the bus to perform Read/Reset, Write, Chip Erase operations. Each bus write cycle must be performed continuously. In addition, whether the automatic algorithm has terminated can be determined using the data polling or other function. At normal termination, the flash memory is returned to the read/reset state. Each operation of the flash memory is described in the following order: 17.5.1 Setting The Read/Reset State 17.5.2 Writing Data 17.5.3 Erasing All Data (Erasing Chips) ## 17.5.1 Setting The Read/Reset State This section describes the procedure for issuing the Read/Reset command to set the flash memory to the read/reset state. #### ■ Setting the Read/Reset State The flash memory can be set to the read/reset state by sending the Read/Reset command in the command sequence table (see Table 17.3-1 in Section "17.3 Starting the Flash Memory Automatic Algorithm ") continuously to the target sector in the flash memory. The Read/Reset command has two types of command sequences that execute the first and third bus operations. However, there are no essential differences between these command sequences. The read/reset state is the initial state of the flash memory. When the power is turned on and when a command terminates normally, the flash memory is set to the read/reset state. In the read/reset state, other commands wait for input. In the read/reset state, data is read by regular read-access. As with the mask ROM, program access from the CPU is enabled. The Read/Reset command is not required to read data by a regular read. The Read/Reset command is mainly used to initialize the automatic algorithm in such cases as when a command does not terminate normally. ## 17.5.2 Writing Data This section describes the procedure for issuing the Write command to write data to the flash memory. Figure 17.5-1 shows an example of the flash memory write procedure. #### ■ Writing Data The data write automatic algorithm of the flash memory can be started by sending the Write command in the command sequence table (see Table 17.3-1 in Section "17.3 Starting the Flash Memory Automatic Algorithm") continuously to the flash memory. When data write to the target address is completed in the fourth cycle, the automatic algorithm and automatic write are started. #### ■ Specifying Addresses Writing can be done in any order of addresses. However, the Write command writes only data of one byte for each execution. ### ■ Notes on Writing Data Writing cannot return data 0 to data 1. When data 1 is written to data 0, the data polling algorithm (DQ7) or toggle operation (DQ6) does not terminate and the flash memory elements are determined to be faulty. If the time prescribed for writing is thus exceeded, the timing limit exceeded flag (DQ5) is determined to be an error. Otherwise, the data is viewed as if dummy data 1 had been written. However, when data is read in the read/reset state, the data remains 0. Data 0 can be set to data 1 only by erase operations. All commands are ignored during execution of the automatic write algorithm. If a hardware reset is started during writing, the data of the written addresses will be unpredictable. #### ■ Writing to the Flash Memory Figure 17.5-1 is an example of the procedure for writing to the flash memory. The hardware sequence flags (see Section "17.4 Confirming the Automatic Algorithm Execution State ") can be used to determine the state of the automatic algorithm in the flash memory. Here, the data polling flag (DQ7) is used to confirm that writing has terminated. The data read to check the flag is read from the address written to last. The data polling flag (DQ7) changes at the same time that the timing limit exceeded flag (DQ5) changes. For example, even if the timing limit exceeded flag (DQ5) is "1", the data polling flag bit (DQ7) must be rechecked. Also for the toggle bit flag (DQ6), the toggle operation stops at the same time that the timing limit exceeded flag bit (DQ5) changes to "1". The toggle bit flag (DQ6) must therefore be rechecked. Figure 17.5-1 Example of the Flash Memory Write Procedure ## 17.5.3 Erasing All Data (Erasing Chips) This section describes the procedure for issuing the Chip Erase command to erase all data in the flash memory. ### **■** Erasing All Data (Erasing Chips) All data can be erased from the flash memory by sending the Chip Erase command in the command sequence table (see Table 17.3-1 in Section "17.3 Starting the Flash Memory Automatic Algorithm ") continuously to the target sector in the flash memory. The Chip Erase command is executed in six bus operations. When writing of the sixth cycle is completed, the chip erase operation is started. For chip erase, the user need not write to the flash memory before erasing. During execution of the automatic erase algorithm, the flash memory writes "0" for verification before all of the cells are erased automatically. ## 17.6 Flash Security Feature Flash security feature provides possibilities to protect the content of the flash memory from being read from external. #### ■ Abstract By writing the protection code of " $01_H$ " to the predefined flash security address of the flash memory, access to the flash memory is restricted. Once the flash memory is protected, unlock the security function can only be done by performing the chip erase operation. Otherwise, read/write access of the flash memory from the external pins is not possible. This function is suitable for applications requiring security of self-containing data stored in the flash memory. Table 17.6-1 Flash Security Address | Product | Flash Memory Size | Flash Security Address | | | |-----------------|-------------------|------------------------|--|--| | MB89F202/F202RA | 16 Kbyte | FFFC <sub>H</sub> | | | #### ■ How to enable the Flash Security Feature After writing the code $"01_H"$ to the flash security address, the subsequent external reset or power on enables the flash security feature. #### ■ How to disable the Flash Security Feature Perform the chip erase operation. #### ■ Behavior under the Flash Security Feature Read operation: invalid data read Write operation: ignored #### Others - For the configuration of the standard parallel programmer, please follow the specification of parallel programmer. - In order to prevent the device form enabling the flash security feature accidentally, writing the protection code at the last of flash memory programming is recommended. #### Note: The security byte is allocated inside the flash memory. After writing the code " $01_H$ " to the flash security address, the subsequent external reset or power on enables the flash security feature. Therefore, if the flash security feature is not required, do not write " $01_H$ " to the security byte address. Once the flash security feature is enabled, all the flash memory failure analysis cannot be performed. ## 17.7 Notes on using Flash Memory ### This section provides notes on using the MB89F202, especially for flash memory. ## ■ Input of a Hardware Reset (RST) To input a hardware reset when reading is in progress, i.e., when the automatic algorithm has not been started, secure a minimum low-level width of 1650 ns. To input a hardware reset while a write or erase is in progress, i.e., while the automatic algorithm is being started, secure a minimum low-level width of 1650 ns. In this case, 20 µs are required until the data becomes readable after the operation being performed terminates and the flash memory is fully initialized. Performing a hardware reset during a write operation makes the data being written undetermined. Also note that performing a hardware reset or shut-down during an erase operation may make the sector from which data is being erased unusable. #### ■ Software Reset, Watchdog Timer Reset When write/erase of flash memory is set up for normal mode and CPU memory access mode is internal ROM mode, and if a reset cause occurs while the automatic algorithm of flash memory is being activated, the CPU may run out of control. The cause of a reset does not initialize the flash memory and keeps the automatic algorithm operating. Thus, when the CPU starts a sequence after the reset is cancelled, the flash memory may not have been in a read state. Prevent a cause of a reset from occurring while the flash memory is writing or erasing. ## ■ Program Access to Flash Memory While the automatic algorithm is being activated, any read access to the flash memory is disabled. When CPU memory access mode is set to internal ROM mode, move program areas into another area such as RAM, and then start a write or erase. In this case, when the flash containing interrupt vectors are erased, the writing or erasing of interrupt processing cannot be executed. For the same reason, other interrupt processing shall be disabled while the automatic algorithm is being activated. #### ■ Flash Content Protection Flash content can be read using parallel / serial programmer if the flash content protection mechanism is not activated. One predefined area of the flash (FFFC<sub>H</sub>) is assigned to be used for preventing the read access of flash content. If the protection code " $01_H$ " is written in this address (FFFC<sub>H</sub>), the flash content cannot be read by any parallel / serial programmer. Note: The program written into the flash cannot be verified once the flash protection code is written (" $01_H$ " in FFFC<sub>H</sub>). It is advised to write the flash protection code at last. ## CHAPTER 17 FLASH MEMORY # **APPENDIX** This appendix shows the I/O map, the overview of the instructions, mask options in MB89202/F202RA series, and the pin states. APPENDIX A I/O Map APPENDIX B Overview of the Instructions APPENDIX C Mask Options APPENDIX D Programming EPROM with Evaluation Chip APPENDIX E Pin State of the MB89202/F202RA Series # APPENDIX A I/O Map For the registers of peripheral functions incorporated in the MB89202/F202RA series, the addresses shown in Table A-1 are assigned. ## ■ I/O Map Table A-1 I/O Map (1 / 4) | | | | + | | | | |----------------------------------------------|--------------------------|----------------------------------|------------|---------------|--|--| | Address | Register<br>abbreviation | Register name | Read/write | Initial value | | | | 0000 <sub>H</sub> | PDR0 | Port 0 data register | R/W | XXXXXXXX | | | | 0001 <sub>H</sub> | DDR0 | Port 0 data direction register | W | 00000000 | | | | 0002 <sub>H</sub><br>to<br>0006 <sub>H</sub> | | Vacancy | | | | | | 0007 <sub>H</sub> | SYCC | System clock control register | R/W | 111100 | | | | 0008 <sub>H</sub> | STBC | Standby control register | R/W | 00010 | | | | 0009 <sub>H</sub> | WDTC | Watchdog control register | R/W | 0XXXX | | | | 000A <sub>H</sub> | TBTC | Time-base timer control register | R/W | 00000 | | | | 000B <sub>H</sub> | Vacancy | | | | | | | 000C <sub>H</sub> | PDR3 | Port 3 data register | R/W | XXXXXXXX | | | | 000D <sub>H</sub> | DDR3 | Port 3 data direction register | W | 00000000 | | | | 000E <sub>H</sub> | RSFR | Reset flag register | R | XXXX | | | | 000F <sub>H</sub> | PDR4 | Port 4 data register | R/W | XXXX | | | | 0010 <sub>H</sub> | DDR4 | Port 4 data direction register | R/W | 0000 | | | | 0011 <sub>H</sub> | OUT4 | Port 4 output format register | R/W | 0000 | | | | 0012 <sub>H</sub> | PDR5 | Port 5 data register | R/W | X | | | | 0013 <sub>H</sub> | DDR5 | Port 5 data direction register | R/W | 0 | | | | 0014 <sub>H</sub> | RCR21 | 12-bit PPG control register 1 | R/W | 00000000 | | | | 0015 <sub>H</sub> | RCR22 | 12-bit PPG control register 2 | R/W | 000000 | | | | 0016 <sub>H</sub> | RCR23 | 12-bit PPG control register 3 | R/W | 0-000000 | | | | 0017 <sub>H</sub> | RCR24 | 12-bit PPG control register 4 | R/W | 000000 | | | Table A-1 I/O Map (2 / 4) | Address | Register<br>abbreviation | Register name | Read/write | Initial value | | | | |----------------------------------------------------------------------------------|--------------------------|-----------------------------------------|------------|---------------|--|--|--| | 0018 <sub>H</sub> | BZCR | Buzzer register | R/W | 000 | | | | | 0019 <sub>H</sub> | TCCR | Capture control register | R/W | 00000000 | | | | | 001A <sub>H</sub> | TCR1 | Timer 1 control register | R/W | 000-0000 | | | | | 001B <sub>H</sub> | TCR0 | Timer 0 control register | R/W | 00000000 | | | | | 001C <sub>H</sub> | TDR1 | Timer 1 data register | R/W | XXXXXXXX | | | | | 001D <sub>H</sub> | TDR0 | Timer 0 data register | R/W | XXXXXXXX | | | | | 001E <sub>H</sub> | ТСРН | Capture data register H | R | XXXXXXXX | | | | | 001F <sub>H</sub> | TCPL | Capture data register L | R | XXXXXXXX | | | | | 0020 <sub>H</sub> | TCR2 | Timer output control register | R/W | 00 | | | | | 0021 <sub>H</sub> | Vacancy | | | | | | | | 0022 <sub>H</sub> | CNTR | PWM control register | R/W | 0-000000 | | | | | 0023 <sub>H</sub> | COMR | PWM compare register | W | XXXXXXXX | | | | | 0024 <sub>H</sub> | EIC1 | External interrupt 1 control register 1 | R/W | 00000000 | | | | | 0025 <sub>H</sub> | EIC2 | External interrupt 1 control register 2 | R/W | 0000 | | | | | 0026 <sub>H</sub> | | TY. | | 1 | | | | | 0027 <sub>H</sub> | | Vacancy | | | | | | | 0028 <sub>H</sub> | SMC | Serial mode control register | R/W | 00000-00 | | | | | 0029 <sub>H</sub> | SRC | Serial rate control register | R/W | 011000 | | | | | 002A <sub>H</sub> | SSD | Serial status and data register | R/W | 00100-1X | | | | | 002B <sub>H</sub> | SIDR | Serial input data register | R | XXXXXXXX | | | | | 002ВН | SODR | Serial output data register | W | XXXXXXXX | | | | | 002C <sub>H</sub> | UPC | Clock divided cycle selection register | R/W | 0010 | | | | | $\begin{array}{c} 002 \mathrm{D_H} \\ \text{to} \\ 002 \mathrm{F_H} \end{array}$ | | Vacancy | | | | | | | 0030 <sub>H</sub> | ADC1 | A/D control register 1 | R/W | -0000000 | | | | | 0031 <sub>H</sub> | ADC2 | A/D control register 2 | R/W | -0000001 | | | | | 0032 <sub>H</sub> | ADDH | A/D data register H | R | XX | | | | | 0033 <sub>H</sub> | ADDL | A/D data register L | R | XXXXXXXX | | | | Table A-1 I/O Map (3 / 4) | Address | Register abbreviation | Register name | Read/write | Initial value | | | | |----------------------------------------------|----------------------------------------------|-----------------------------------------|------------|---------------|--|--|--| | 0034 <sub>H</sub> | ADEN | A/D enable register | R/W | 00000000 | | | | | 0035 <sub>H</sub> | Vacancy | | | | | | | | 0036 <sub>H</sub> | EIE2 External interrupt 2 control register 1 | | R/W | 00000000 | | | | | 0037 <sub>H</sub> | EIF2 | External interrupt 2 control register 2 | R/W | 0 | | | | | 0038 <sub>H</sub> | | Vacancy | · | | | | | | 0039 <sub>H</sub> | SMR | Serial mode register | R/W | 00000000 | | | | | 003A <sub>H</sub> | SDR | Serial data register | R/W | XXXXXXXX | | | | | 003B <sub>H</sub> | SSEL | Serial function switching register | R/W | 0 | | | | | 003C <sub>H</sub><br>to<br>003F <sub>H</sub> | Vacancy | | | | | | | | 0040 <sub>H</sub> | WRARH0 | Higher address set register 0 | R/W | XXXXXXXX | | | | | 0041 <sub>H</sub> | WRARL0 | Lower address set register 0 | R/W | XXXXXXXX | | | | | 0042 <sub>H</sub> | WRDR0 | Data setting register 0 | R/W | XXXXXXXX | | | | | 0043 <sub>H</sub> | WRARH1 | Higher address set register 1 | R/W | XXXXXXXX | | | | | 0044 <sub>H</sub> | WRARL1 | Lower address set register 1 | R/W | XXXXXXXX | | | | | 0045 <sub>H</sub> | WRDR1 | Data setting register 1 | R/W | XXXXXXXX | | | | | 0046 <sub>H</sub> | WREN | Address comparison EN register | R/W | 00 | | | | | 0047 <sub>H</sub> | WROR | Wild register data test register | R/W | 00 | | | | | 0048 <sub>H</sub><br>to<br>005F <sub>H</sub> | | Vacancy | | | | | | | 0060 <sub>H</sub> | PDR6 | Port 6 data register | R/W | XX | | | | | 0061 <sub>H</sub> | DDR6 | Port 6 data direction register* | R/W | 00 | | | | | 0062 <sub>H</sub> | PUL6 | Port 6 pull-up set register | R/W | 00 | | | | | 0063 <sub>H</sub> | PDR7 | Port 7 data register | R/W | XXX | | | | | 0064 <sub>H</sub> | DDR7 | Port 7 data direction register | R/W | 000 | | | | | 0065 <sub>H</sub> | PUL7 | Port 7 pull-up set register | R/W | 000 | | | | Table A-1 I/O Map (4 / 4) | Address | Register<br>abbreviation | Register name | Read/write | Initial value | | | | |----------------------------------------------|--------------------------|--------------------------------------|------------|---------------|--|--|--| | 0066 <sub>H</sub><br>to<br>006F <sub>H</sub> | Vacancy | | | | | | | | 0070 <sub>H</sub> | PUL0 | Port 0 pull-up set register | R/W | 00000000 | | | | | 0071 <sub>H</sub> | PUL3 | Port 3 pull-up set register | R/W | 00000000 | | | | | 0072 <sub>H</sub> | PUL5 | Port 5 pull-up set register | R/W | 0 | | | | | 0073 <sub>H</sub><br>to<br>0078 <sub>H</sub> | Prohibited area | | | | | | | | 0079 <sub>H</sub> | FMCS | Flash memory control status register | R/W, R | 000X | | | | | 007A <sub>H</sub> | | Prohibited area | | | | | | | 007B <sub>H</sub> | ILR1 | Interrupt level set register 1 | W | 11111111 | | | | | 007C <sub>H</sub> | ILR2 | Interrupt level set register 2 | W | 11111111 | | | | | 007D <sub>H</sub> | ILR3 | Interrupt level set register 3 | W | 11111111 | | | | | 007E <sub>H</sub> | ILR4 | Interrupt level set register 4 | W | 11111111 | | | | | 007F <sub>H</sub> | ITR | Interrupt test register | Inhibited | 00 | | | | ## Explanation on read/write R/W: Readable and Writable R: Read only W: Write only #### Explanation on initial value 0: The initial value of this bit is "0". 1: The initial value of this bit is "1". X: The initial value of this bit is undefined. \*: No used in MB89F202/F202RA. #### Note: Do not use the prohibited areas. ## **APPENDIX B** Overview of the Instructions ## This section describes the instructions used for the F<sup>2</sup>MC-8L. # ■ Overview of the Instructions of the F<sup>2</sup>MC-8L The $F^2MC-8L$ has 140 kinds of 1-byte machine instructions (actually, the map is 256 bytes). An instruction and succeeding operands make an instruction code. Figure B-1 shows the correspondence between the instruction codes and instruction map. Figure B-1 Correspondence between Instruction Codes and Instruction Map - The instructions are classified into four groups including transfer instructions and branch instructions. - Various methods for addressing are supported. Depending on the selection of an instruction and specification of operands, 10 kinds of addressing can be selected. - Bit manipulation instructions are supported, so read-modify-write operation is possible. - Instructions directing special operations are supported. # **■** Explanation on the Codes Representing Instructions Table B-1 describes the codes used to explain the instruction codes in Appendix B. Table B-1 Explanation on Codes on Instructions' List | Code | Meaning | |-------|----------------------------------------------------------------------------------------------------------------------------------------| | dir | Direct address (8 bits) | | off | Offset (8 bits) | | ext | Extended address (16 bits) | | #vct | Vector table number (3 bits) | | #d8 | Immediate data (8 bits) | | #d16 | Immediate data (16 bits) | | dir:b | Bit direct address (8:3 bits) | | rel | Branch relative address (8 bits) | | @ | Register indirect (Example: @A, @IX, and @EP) | | A | Accumulator (8 bits or 16 bits, determined on basis of instruction to be used) | | АН | Higher 8 bits of the accumulator (8 bits) | | AL | Lower 8 bits of the accumulator (8 bits) | | Т | Temporary accumulator (8 bits or 16 bits, determined on basis of instruction to be used) | | TH | Higher 8 bits of the temporary accumulator (8 bits) | | TL | Lower 8 bits of the temporary accumulator (8 bits) | | IX | Index register (16 bits) | | EP | Extra pointer (16 bits) | | PC | Program counter (16 bits) | | SP | Stack pointer (16 bits) | | PS | Program status (16 bits) | | dr | Either accumulator or index register (16 bits) | | CCR | Condition code register (8 bits) | | RP | Register bank pointer (5 bits) | | Ri | General-purpose register (8 bits, $i = 0$ to 7) | | X | Indicates that X itself is the immediate data. (8 bits or 16 bits, determined on basis of instruction to be used) | | (X) | Indicates that the contents of X is the accessing subject. (8 bits or 16 bits, determined on basis of instruction to be used) | | ((X)) | Indicates that the address specified in X is the accessing subject. (8 bits or 16 bits, determined on basis of instruction to be used) | # ■ Explanation on the Items of Instructions' List Table B-2 Explanation on Items of Instructions' List | Item | Description | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MNEMONIC | Represents the instruction coded in the assembler. | | ~ | Indicates the number of cycles of the instruction (number of instruction cycles). | | # | Indicates the number of bytes of the instruction. | | Operation | Indicates the operation of the instruction. | | TL,TH,AH | Indicates how the contents of TL, TH, and AH change (automatic transfer from A to T) when the instruction is executed. The codes in this column indicate the following: - indicates no change. dH indicates the higher 8 bits of the data coded for the operation. AL and AH indicate the contents of AL and AH just before the execution of the instruction. 00 indicates that it becomes 00. | | N,Z,V,C | Indicates whether the instruction changes the corresponding flags. If ( is shown in this column, the instruction changes the corresponding flags. | | OP CODE | Indicates the instruction code. If the appropriate instruction occupies multiple codes, they are listed under the following rule: Example: 48 to 4F means the serial numbers from 48 to 4F. | # **B.1** Addressing For the $F^2MC-8L$ , the following 10 kinds of addressing modes are supported: - Direct addressing - Extended addressing - · Bit direct addressing - Index addressing - Pointer addressing - General-purpose register addressing - · Immediate addressing - Vector addressing - Relative addressing - · Inherent addressing #### **■** Explanation on Addressing #### Direct addressing The addressing, which is indicated by dir in the instructions list, is used for accessing the area from $0000_{\rm H}$ to $00FF_{\rm H}$ . In this addressing, the higher one byte of the address is $00_{\rm H}$ . Specify the lower one byte with the operand. Figure B.1-1 shows an example. Figure B.1-1 Example of Direct Addressing #### Extended Addressing The addressing, which is indicated by ext in the instructions list, is used for accessing the entire area of 64 KB. In this addressing, specify the higher one byte of the address with the first operand and the lower one byte with the second operand. Figure B.1-2 shows an example. Figure B.1-2 Example of Extended Addressing #### Bit Direct Addressing The addressing, which is indicated by dir:b in the instructions list, is used for accessing the area from $0000_{\rm H}$ to $00{\rm FF}_{\rm H}$ on a per bit basis. In this addressing, the higher one byte of the address is $00_{\rm H}$ . Specify the lower one byte with the operand; and the bit position in the specified address with the lower three bits of the operation code. Figure B.1-3 shows an example. Figure B.1-3 Example of Bit Direct Addressing #### Index addressing The addressing, which is indicated by @IX(off in the instructions list, is used for accessing the entire area of 64 KB. In this addressing, the contents of the first operand are signed and added to IX (index register). Then the results are used as the address. Figure B.1-4 shows an example. Figure B.1-4 Example of Index Addressing #### Pointer Addressing The addressing, which is indicated by @EP in the instructions list, is used for accessing the entire area of 64 KB. In this addressing, the contents of EP (extra pointer) are used as the address. Figure B.1-5 shows an example. Figure B.1-5 Example of Pointer Addressing #### General-purpose Register Addressing The addressing, which is indicated by Ri in the instructions list, is used for accessing the register bank of the general-purpose register area. In this addressing, the higher one byte of the address is fixed to 01. The lower one byte is generated from the contents of RP (register bank pointer) and the lower three bits of the operation code. The address is then accessed. Figure B.1-6 shows an example. Figure B.1-6 Example of General-purpose Register Addressing #### Immediate Addressing The addressing, which is indicated by #d8 in the instructions list, is used when immediate data is required. In this addressing, the operand directly becomes the immediate data. The specification of byte/word is determined using the operation code. Figure B.1-7 shows an example. Figure B.1-7 Example of Immediate Addressing #### Vector Addressing The addressing, which is indicated by vct in the instructions list, is used for branching to a subroutine registered in the table. In this addressing, the operation code includes the vct information, with the addresses generated on the basis of the correspondence with the contents of Table B.1-1. Table B.1-1 Vector Table Address Corresponding to vct | #vct | Vector table address (Jump destination, higher address:lower address) | |------|-----------------------------------------------------------------------| | 0 | FFCO <sub>H</sub> : FFC1 <sub>H</sub> | | 1 | FFC2 <sub>H</sub> : FFC3 <sub>H</sub> | | 2 | FFC4 <sub>H</sub> : FFC5 <sub>H</sub> | | 3 | FFC6 <sub>H</sub> : FFC7 <sub>H</sub> | | 4 | FFC8 <sub>H</sub> : FFC9 <sub>H</sub> | | 5 | FFCA <sub>H</sub> : FFCB <sub>H</sub> | | 6 | $FFCC_H$ : $FFCD_H$ | | 7 | $FFCE_H: FFCF_H$ | Figure B.1-8 shows an example. Figure B.1-8 Example of Vector Addressing #### Relative Addressing The addressing, which is indicated by rel in the instructions list, is used for branching to the area of 128 bytes before or after the PC (program counter). In this addressing, the contents of the operand with a sign are added to the PC. The results are then stored in the PC. Figure B.1-9 shows an example. Figure B.1-9 Example of Relative Addressing In this example, the control jumps to the address holding the operation code of BNE, causing an endless loop. #### Inherent addressing This addressing, which has no operand in the instructions list, is used for performing an operation determined on the basis of the operation code. In this addressing, the operations differ depending on the instructions. Figure B.1-10 shows an example. Figure B.1-10 Example of Inherent Addressing # **B.2** Special Instructions ### This section describes the special instructions other than addressing. ### ■ Special Instructions #### JMP @A By this instruction, the control branches to PC (program counter) using the contents of A (accumulator) as the address. N items of jump destinations have been listed on the table, one of which is selected and transferred to A. Executing this instruction can achieve N kinds of branch processing. Figure B.2-1 shows an overview. Figure B.2-1 JMP @A #### MOVW A, PC This instruction performs the opposite operation of JMP @A. In other words, the contents of the PC are stored in A. When this instruction has been executed in the main routine and a specific subroutine is to be called, it is possible to verify that the contents of A are the predetermined value in the subroutine. It is also possible to verify that the branch was not from an unexpected part, so it is useful in judging that a runaway has occurred. Figure B.2-2 shows an overview. Figure B.2-2 MOVW A, PC When this instruction is executed, the contents of A are not the address holding the operation code of this instruction but the same value as the address holding the next instruction. In Figure B.2-2, therefore, the value stored in A, $1234_{\rm H}$ , is the same as the address holding the operation code next to the MOVW A, PC. #### MULU A This instruction multiplies AL (the lower eight bits of accumulator) by TL (the lower eight bits of the temporary accumulator) without a sign and stores the results in 16 bits length to A. The contents of T (temporary accumulator) remain as they are. For the operation, the contents of AH (the higher eight bits of accumulator) and TH (the higher eight bits of temporary accumulator) before the execution are not used. Take care when using a branch based on the result of multiplication because the flags were not changed. Figure B.2-3 shows an overview. Figure B.2-3 MULU A #### DIVU A This instruction divides T of 16 bits by AL of 8 bits without a sign, stores the results in 8 bits to AL, and stores the remainder of 8 bits to TL. Both AH and TH become 0. For the operation, the contents of AH before execution are not used. If the results exceed 8 bits, they are not guaranteed. Also, the fact that the results exceeded 8 bits is not indicated. So when using data units that may cause this type of situation, judge them in advance. Take care when using a branch based on the result of division, because the flags were not changed. Figure B.2-4 shows an overview. Figure B.2-4 DIVU A #### XCHW A, PC This instruction replaces the contents of A and the contents of PC, resulting in a branch to the address indicated by the contents of A before execution. The contents of A after execution become the value of the address next to the address holding the operation code, XCHW A, PC. This instruction is useful especially when a table is specified in the main routine and a subroutine uses it. Figure B.2-5 shows an overview. Figure B.2-5 XCHW A, PC After execution of this instruction, the contents of A do not become the address holding the operation code of this instruction. Instead, they are the same as the address holding the next instruction. In Figure B.2-5, therefore, the value stored in A is $1235_{\rm H}$ , agreeing with the address holding the operation code next to XCHW A, PC. Note that it is not $1234_{\rm H}$ but $1235_{\rm H}$ . Figure B.2-6 shows an example of assembler coding. (Main routine) (Subroutine) MOVW A, #PUTSUB → PUTSUB XCHW A, EP **XCHW** A, PC PUSHW A DB PTS1 MOV A, @EP 'PUT OUT DATA', EOL MOVW A, 1234H <sup>←</sup> INCW EP Outputs a MOV IO, A table data CMP A, #EOL unit. BNE PTS1 POPW A XCHW A, EP JMP @A Figure B.2-6 Usage Example of XCHW A, PC #### CALLV #vct This addressing is used for branching to one of the subroutine addresses registered in the table. After the return address (the contents of PC) is saved to the address indexed by SP (stack pointer), the control is branched to the address listed in the vector table via the vector addressing. This instruction is one byte, so using it for the frequently used subroutines enables the entire program size to be smaller. Figure B.2-7 shows the overview. (Before execution) (After execution) 5678<sub>H</sub> → PC | FEDCH PC 1234<sub>H</sub> 1232<sub>H</sub> SP 1232<sub>H</sub> 1232<sub>H</sub> ХХн 56н 1233<sub>H</sub> ХХн 1233<sub>H</sub> 79⊦ FFC6<sub>H</sub> FFC6<sub>H</sub> FEH FEH FFC7<sub>H</sub> DСн $FFC7_H$ DСн Figure B.2-7 Executing Example of CALLV #3 When this instruction is executed, the contents of the PC to be saved in the stack area are not the address holding the operation code of this instruction. Instead, they comprise the address holding the next instruction. In Figure B.2-7, therefore, the value saved in the stack $(1232_H \text{ and } 1233_H)$ is the same as the address holding the operation code next to CALLV #vct (return address), i.e. $5679_H$ . # **B.3** Bit Manipulation Instructions (SETB and CLRB) Some registers of peripheral functions have bits that perform a read operation different from ordinary read for a bit manipulation instruction. #### ■ Read-modify-write Operation The bit manipulation instructions can set "1" (SETB) to the specified bit in a register or RAM or clear it to "0" (CLRB). Because the CPU handles the data in 8 bits, however, it actually reads the 8-bit data, modifies the specified bit, and then writes it back to the original address. This series of operations is called read-modify-write operation. Table B.3-1 shows the bus operation at bit manipulation instructions. Table B.3-1 Bus Operation at Bit Manipulation Instructions | CODE | MNEMONIC | ~ | Cycle | Address bus | Data bus | RD | WR | RMW | |----------|------------|---|-------|-------------|----------------|----|----|-----| | A0 to A7 | CLRB dir:b | 4 | 1 | N+1 | Dir | 0 | 1 | 0 | | | | | 2 | dir address | Data | 0 | 1 | 1 | | A8 to AF | SETB dir:b | | 3 | dir address | Data | 1 | 0 | 0 | | | | | 4 | N+2 | Next operation | 0 | 1 | 0 | ### ■ Read Destination at Execution of a Bit Manipulation Instruction For some I/O ports and interrupt request flag bits, the read destination for read-modify-write is different from that for ordinary read. #### • I/O port (at bit manipulation) For some I/O ports, the value of the I/O pin is read at ordinary read; meanwhile, the value of output latch is read at bit manipulation. This is to prevent the other bits of the output latch from being accidentally changed regardless of the I/O direction and pin state. #### Interrupt request flag bit (at bit manipulation) The interrupt request flag bits work as flag bits for confirming an interrupt request at ordinary read; meanwhile, "1" is always read at bit manipulation. This is to prevent the interrupt request flag bits from being written as "0", and accidentally clearing the flags at bit manipulation for another bit. # B.4 F<sup>2</sup>MC-8L Instructions List # Table B.4-1 to Table B.4-4 list the instructions used by the $F^2MC-8L$ . ### **■** Transfer Instructions Table B.4-1 List of Transfer Instructions (1 / 2) | No. | MNEMONIC | ~ | # | Operation | TL | TH | АН | N | Z | V | С | OP CODE | |-----|------------------|---|---|----------------------------------------------------|----|----|----|---|---|---|---|----------| | 1 | MOV dir, A | 3 | 2 | $(dir) \leftarrow (A)$ | - | - | - | - | - | - | - | 45 | | 2 | MOV @IX+off, A | 4 | 2 | $((IX) + off) \leftarrow (A)$ | - | - | - | - | - | - | - | 46 | | 3 | MOV ext, A | 4 | 3 | $(ext) \leftarrow (A)$ | - | - | - | - | - | - | - | 61 | | 4 | MOV @EP, A | 3 | 1 | ( (EP) ) ←(A) | - | - | - | - | - | - | - | 47 | | 5 | MOV Ri, A | 3 | 1 | (Ri) ←(A) | - | - | - | - | - | - | - | 48 to 4F | | | | | | | | | | | | | | | | 6 | MOV A, #d8 | 2 | 2 | A) ←d8 | AL | - | - | + | + | - | - | 04 | | 7 | MOV A, dir | 3 | 2 | (A) ←(dir) | AL | - | - | + | + | - | - | 05 | | 8 | MOV A, @IX +off | 4 | 2 | $(A) \leftarrow ((IX) + off)$ | AL | - | - | + | + | - | - | 06 | | 9 | MOV A, ext | 4 | 3 | (A) ←(ext) | AL | - | - | + | + | - | - | 60 | | 10 | MOV A, @A | 3 | 1 | $(A) \leftarrow ((A))$ | AL | - | - | + | + | - | - | 92 | | | | | | | | | | | | | | | | 11 | MOV A, @EP | 3 | 1 | $(A) \leftarrow ((EP))$ | AL | - | - | + | + | - | - | 07 | | 12 | MOV A, Ri | 3 | 1 | (A) ←(Ri) | AL | - | - | + | + | - | - | 08 to 0F | | 13 | MOV dir, #d8 | 4 | 3 | (dir) ←d8 | - | - | - | - | - | - | - | 85 | | 14 | MOV @IX+off, #d8 | 5 | 3 | $((IX) + off) \leftarrow d8$ | - | - | - | - | - | - | - | 86 | | 15 | MOV @EP, #d8 | 4 | 2 | ((EP)) ←d8 | - | - | - | - | - | - | - | 87 | | | | | | | | | | | | | | | | 16 | MOV Ri, #d8 | 4 | 2 | (Ri) ←d8 | - | - | - | - | - | - | - | 88 to 8F | | 17 | MOVW dir, A | 4 | 2 | $(dir) \leftarrow (AH),$ $(dir+1) \leftarrow (AL)$ | - | - | - | - | - | - | - | D5 | | 18 | MOVW @IX+off , A | 5 | 2 | $((IX)+off) \leftarrow (AH),$ $((IX)+off+1$ | - | - | - | - | - | - | - | D6 | | 19 | MOVW ext, A | 5 | 3 | $(ext) \leftarrow (AH),$ $(ext+1) \leftarrow (AL)$ | - | - | - | - | - | - | - | D4 | | 20 | MOVW @EP, A | 4 | 1 | ( (EP) ) ←(AH),<br>( (EP)+1) ←(AL) | - | - | - | - | - | - | - | D7 | | 21 | MOVW EP, A | 2 | 1 | (EP) ←(A) | - | - | - | - | - | - | - | E3 | | 22 | MOVW A, #d16 | 3 | 3 | (A) ←d16 | AL | AH | dH | + | + | - | - | E4 | Table B.4-1 List of Transfer Instructions (2 / 2) | No. | MNEMONIC | ~ | # | Operation | TL | TH | АН | N | Z | V | С | OP CODE | |-----|-----------------|---|---|------------------------------------------------------------|----|----|----|---|---|---|---|----------| | 23 | MOVW A, dir | 4 | 2 | (AH) ←(dir),<br>(AL) ←(dir+1) | AL | АН | dH | + | + | - | - | C5 | | 24 | MOVW A, @IX+off | 5 | 2 | $(AH) \leftarrow ((IX) + off),$<br>$(AL) \leftarrow ((IX)$ | AL | АН | dH | + | + | - | - | C6 | | 25 | MOVW A, ext | 5 | 3 | $(AH) \leftarrow (ext),$ $(AL) \leftarrow (ext+1)$ | AL | АН | dH | + | + | - | - | C4 | | 26 | MOVW A, @A | 4 | 1 | $(AH) \leftarrow ((A)),$ $(AL) \leftarrow ((A)+1)$ | AL | АН | dH | + | + | - | - | 93 | | 27 | MOVW A, @EP | 4 | 1 | $(AH) \leftarrow ((EP)),$<br>$(AL) \leftarrow ((EP)+1)$ | AL | АН | dH | + | + | - | - | C7 | | 28 | MOVW A, EP | 2 | 1 | (A) ←(EP) | - | - | dH | - | - | - | - | F3 | | 29 | MOVW EP, #d16 | 3 | 3 | (EP) ←d16 | - | - | - | - | - | - | - | E7 | | 30 | MOVW IX, A | 2 | 1 | (IX) ←(A) | - | - | - | - | - | - | - | E2 | | 31 | MOVW A, IX | 2 | 1 | $(A) \leftarrow (IX)$ | - | - | dH | - | _ | | _ | F2 | | 32 | MOVW SP, A | 2 | 1 | (SP) ←(A) | _ | - | - | - | _ | _ | _ | E1 | | 33 | MOVW A, SP | 2 | 1 | (A) ←(SP) | _ | - | dH | _ | _ | _ | _ | F1 | | 34 | MOV @A, T | 3 | 1 | $((A)) \leftarrow (T)$ | _ | - | - | _ | _ | _ | _ | 82 | | 35 | MOVW @A, T | 4 | 1 | $((A)) \leftarrow (TH), )$ $((A)+1) \leftarrow (TL)$ | - | - | - | - | - | - | - | 83 | | | | | | | | | | | | | | | | 36 | MOVW IX, #d16 | 3 | 3 | (IX) ←d16 | - | - | - | - | - | - | - | E6 | | 37 | MOVW A, PS | 2 | 1 | (A) ←(PS) | - | - | dH | - | - | - | - | 70 | | 38 | MOVW PS, A | 2 | 1 | (PS) ←(A) | - | - | - | + | + | + | + | 71 | | 39 | MOVW SP, #d16 | 3 | 3 | (SP) ←d16 | - | - | - | - | - | - | - | E5 | | 40 | SWAP | 2 | 1 | (AH) ← (AL) | - | - | AL | - | - | - | - | 10 | | 41 | SETB dir:b | 4 | 2 | (dir):b ←1 | - | - | - | - | _ | _ | _ | A8 to AF | | 42 | CLRB dir:b | 4 | 2 | (dir):b ←0 | _ | - | - | - | _ | _ | _ | A0 to A7 | | 43 | XCH A, T | 2 | 1 | $(AL) \longleftrightarrow (TL)$ | AL | - | _ | - | _ | _ | - | 42 | | 44 | XCHW A, T | 3 | 1 | (A) ←→(T) | AL | АН | dH | - | - | - | - | 43 | | 45 | XCHW A, EP | 3 | 1 | (A) ←→(EP) | - | - | dH | - | - | - | - | F7 | | 46 | XCHW A, IX | 3 | 1 | $(A) \longleftrightarrow (IX)$ | - | - | dH | - | - | - | - | F6 | | 47 | XCHW A, SP | 3 | 1 | (A) ←→(SP) | - | - | dH | - | - | - | - | F5 | | 48 | MOVW A, PC | 2 | 1 | (A) ←(PC) | - | - | dH | - | - | - | - | F0 | #### Note: At byte transfer operation to A, the automatic transfer to T is represented by $TL \leftarrow AL$ . The operands in a multiple-operand instruction are stored in the order in which they are indicated in MNEMONIC. # **■** Operation Instructions Table B.4-2 List of Operation Instructions (1 / 4) | No. | MNEMONIC | ~ | # | Operation | TL | TH | АН | N | Z | V | С | OP CODE | |-----|-----------------|----|---|------------------------------------------------|----|----|----|---|---|---|---|----------| | 1 | ADDC A, Ri | 3 | 1 | $(A) \leftarrow (A) + (Ri) + C$ | - | - | - | + | + | + | + | 28 to 2F | | 2 | ADDC A, #d8 | 2 | 2 | (A) ←(A)+d8+C | - | - | - | + | + | + | + | 24 | | 3 | ADDC A, dir | 3 | 2 | $(A) \leftarrow (A) + (dir) + C$ | - | - | - | + | + | + | + | 25 | | 4 | ADDC A, @IX+off | 4 | 2 | $(A) \leftarrow (A) + ((IX) + off) + C$ | - | - | - | + | + | + | + | 26 | | 5 | ADDC A, @EP | 3 | 1 | $(A) \leftarrow (A) + ((EP)) + C$ | - | - | - | + | + | + | + | 27 | | | | | | | | | | | | | | | | 6 | ADDCW A | 3 | 1 | $(A) \leftarrow (A) + (T) + C$ | - | - | dH | + | + | + | + | 23 | | 7 | ADDC A | 2 | 1 | $(AL) \leftarrow (AL) + (TL) + C$ | - | - | - | + | + | + | + | 22 | | 8 | SUBC A, Ri | 3 | 1 | (A) ←(A)-(Ri)-C | - | - | - | + | + | + | + | 38 to 3F | | 9 | SUBC A, #d8 | 2 | 2 | (A) ←(A)-d8-C | - | - | - | + | + | + | + | 34 | | 10 | SUBC A, dir | 3 | 2 | (A) ←(A)-(dir)-C | - | - | - | + | + | + | + | 35 | | | | | | | | | | | | | | | | 11 | SUBC A, @IX+off | 4 | 2 | $(A) \leftarrow (A)-((IX)+off)-C$ | - | - | - | + | + | + | + | 36 | | 12 | SUBC A, @EP | 3 | 1 | (A) ←(A)-( (EP) )-C | - | - | - | + | + | + | + | 37 | | 13 | SUBCW A | 3 | 1 | (A) ←(T)-(A)-C | - | - | dH | + | + | + | + | 33 | | 14 | SUBC A | 2 | 1 | $(AL) \leftarrow (TL)-(AL)-C$ | - | - | - | + | + | + | + | 32 | | 15 | INC Ri | 4 | 1 | (Ri) ←(Ri)+1 | - | - | - | + | + | + | - | C8 to CF | | | | | | | | | | | | | | | | 16 | INCW EP | 3 | 1 | (EP) ←(EP)+1 | - | - | - | - | - | - | - | C3 | | 17 | INCW IX | 3 | 1 | $(IX) \leftarrow (IX)+1$ | - | - | - | - | - | - | - | C2 | | 18 | INCW A | 3 | 1 | (A) ←(A)+1 | - | - | dH | + | + | - | - | C0 | | 19 | DEC Ri | 4 | 1 | (Ri) ←(Ri)-1 | - | - | - | + | + | + | - | D8 to DF | | 20 | DECW EP | 3 | 1 | (EP) ←(EP)-1 | - | - | - | - | - | - | - | D3 | | | | | | | | | | | | | | | | 21 | DECW IX | 3 | 1 | (IX) ←(IX)-1 | - | - | - | - | - | - | - | D2 | | 22 | DECW A | 3 | 1 | (A) ←(A)-1 | - | - | dH | + | + | - | - | D0 | | 23 | MULU A | 19 | 1 | $(A) \leftarrow (AL) \times (TL)$ | - | - | dH | + | + | + | + | 01 | | 24 | DIVU A | 21 | 1 | $(A) \leftarrow (T)/(AL), MOD \rightarrow (T)$ | dL | 00 | 00 | - | - | - | - | 11 | Table B.4-2 List of Operation Instructions (2 / 4) | No. | MNEMONIC | ~ | # | Operation | TL | TH | АН | N | Z | V | С | OP CODE | |-----|----------------|---|---|--------------------------------|----|----|----|---|---|---|---|----------| | 25 | ANDW A | 3 | 1 | $(A) \leftarrow (A) \land (T)$ | - | - | dH | + | + | R | - | 63 | | 26 | ORW A | 3 | 1 | (A) ← (A) V (T) | - | - | dH | + | + | R | - | 73 | | 27 | XORW A | 3 | 1 | (A) ← (A) ∀ (T) | - | - | dH | + | + | R | - | 53 | | 28 | CMP A | 2 | 1 | (TL) - (AL) | - | - | - | + | + | + | + | 12 | | 29 | CMPW A | 3 | 1 | (T)- (A) | - | - | - | + | + | + | + | 13 | | 30 | RORC A | 2 | 1 | _> C → A | - | - | - | + | + | - | + | 03 | | 31 | ROLC A | 2 | 1 | C ← A ← | - | - | - | + | + | - | + | 02 | | 32 | CMP A, #d8 | 2 | 2 | (A) - d8 | - | - | - | + | + | + | + | 14 | | 33 | CMP A, dir | 3 | 2 | (A) - (dir) | - | - | - | + | + | + | + | 15 | | 34 | CMP A, @EP | 3 | 1 | (A) - ( (EP) ) | - | - | - | + | + | + | + | 17 | | 35 | CMP A, @IX+off | 4 | 2 | (A)-( (IX)+off) | - | - | - | + | + | + | + | 16 | | 36 | CMP A, Ri | 3 | 1 | (A) - (Ri) | - | - | - | + | + | + | + | 18 to 1F | | 37 | DAA | 2 | 1 | decimal adjust for addition | - | - | - | + | + | + | + | 84 | | 38 | DAS | 2 | 1 | decimal adjust for subtraction | - | - | - | + | + | + | + | 94 | | 39 | XOR A | 2 | 1 | (A) ← (AL) ∀ (TL) | - | - | - | + | + | R | - | 52 | | 40 | XOR A, #d8 | 2 | 2 | (A) ← (AL) ∀ d8 | - | - | - | + | + | R | - | 54 | | 41 | XOR A, dir | 3 | 2 | (A) ← (AL) ∀ (dir) | - | - | - | + | + | R | - | 55 | | 42 | XOR A, @EP | 3 | 1 | (A) ← (AL) ∀ ( (EP) ) | - | - | - | + | + | R | - | 57 | Table B.4-2 List of Operation Instructions (3 / 4) | No. | MNEMONIC | ~ | # | Operation | TL | TH | АН | N | Z | V | С | OP CODE | |-----|----------------|---|---|--------------------------------------------|----|----|----|---|---|---|---|----------| | 43 | XOR A, @IX+off | 4 | 2 | $(A) \leftarrow (AL) \forall ((IX) + off)$ | - | - | - | + | + | R | - | 56 | | 44 | XOR A, Ri | 3 | 1 | (A) ← (AL) ∀ (Ri) | - | - | - | + | + | R | - | 58 to 5F | | 45 | AND A | 2 | 1 | $(A) \leftarrow (AL) \wedge (TL)$ | - | - | - | + | + | R | - | 62 | | 16 | AND A #10 | 2 | 2 | | | | | | | | | 64 | | 46 | AND A, #d8 | | | (A) ← (AL) ∧ d8 | - | - | - | + | + | R | - | 64 | | 47 | AND A, dir | 3 | 2 | $(A) \leftarrow (AL) \land (dir)$ | - | - | - | + | + | R | - | 65 | | 48 | AND A, @EP | 3 | 1 | $(A) \leftarrow (AL) \land ((EP))$ | - | - | - | + | + | R | - | 67 | | 49 | AND A, @IX+off | 4 | 2 | $(A) \leftarrow (AL) \land ((IX)+off)$ | - | - | - | + | + | R | - | 66 | | 50 | AND A, Ri | 3 | 1 | (A) ← (AL) Λ (Ri) | - | - | - | + | + | R | - | 68 to 6F | | 51 | OR A | 2 | 1 | (A) ← (AL) ∨ (Ri) | - | - | - | + | + | R | - | 72 | | 52 | OR A, #d8 | 2 | 2 | (A) ← (AL) ∨ d8 | - | - | - | + | + | R | - | 74 | | 53 | OR A, dir | 3 | 2 | $(A) \leftarrow (AL) \lor (dir)$ | - | - | - | + | + | R | - | 75 | | 54 | OR A, @EP | 3 | 1 | (A) ← (AL) ∨ ( (EP) ) | - | - | - | + | + | R | - | 77 | | 55 | OR A, @IX+off | 4 | 2 | $(A) \leftarrow (AL) \lor ((IX)+off)$ | - | - | - | + | + | R | - | 76 | | 56 | OR A, Ri | 3 | 1 | (A) ← (AL) ∨ (Ri) | - | - | - | + | + | R | - | 78 to 7F | | 57 | CMP dir,#d8 | 5 | 3 | (dir)-d8 | - | - | - | + | + | + | + | 95 | Table B.4-2 List of Operation Instructions (4 / 4) | No. | MNEMONIC | ~ | # | Operation | TL | TH | АН | Ν | Z | V | С | OP CODE | |-----|------------------|---|---|----------------|----|----|----|---|---|---|---|----------| | 58 | CMP @EP, #d8 | 4 | 2 | ( (EP) )-d8 | - | - | - | + | + | + | + | 97 | | 59 | CMP @IX+off, #d8 | 5 | 3 | ( (IX)+off)-d8 | - | - | - | + | + | + | + | 96 | | 60 | CMP Ri, #d8 | 4 | 2 | (Ri)-d8 | - | - | - | + | + | + | + | 98 to 9F | | | | | | | | | | | | | | | | 61 | INCW SP | 3 | 1 | (SP) ←(SP)+1 | - | - | - | - | - | - | - | C1 | | 62 | DECW SP | 3 | 1 | (SP) ←(SP)-1 | - | - | - | - | - | - | - | D1 | # **■** Branch Instructions Table B.4-3 List of Branch Instructions | No. | MNEMONIC | ~ | # | Operation | TL | TH | АН | N | Z | V | С | OP CODE | |-----|----------------|---|---|-----------------------------------------------|----|----|----|---|-----|------|---|----------| | 1 | BZ/BEQ rel | 3 | 2 | if Z=1 then PC ←PC+rel | - | - | - | - | - | - | - | FD | | 2 | BNZ/BNE rel | 3 | 2 | if Z=0 then PC ←PC+rel | - | - | - | - | - | - | - | FC | | 3 | BC/BLO rel | 3 | 2 | if C=1 then PC ←PC+rel | - | - | - | - | - | - | - | F9 | | 4 | BNC/BHS rel | 3 | 2 | if C=0 then PC ←PC+rel | - | - | - | - | - | - | - | F8 | | 5 | BN rel | 3 | 2 | if N=1 then PC ←PC+rel | - | - | - | - | - | - | - | FB | | | | | | | | | | | | | | | | 6 | BP rel | 3 | 2 | if N=0 then PC ←PC+rel | - | - | - | - | - | - | - | FA | | 7 | BLT rel | 3 | 2 | if V ∀ N=1 then PC ← PC+rel | - | - | - | - | - | - | - | FF | | 8 | BGE rel | 3 | 2 | if $V \nabla N=0$ then $PC \leftarrow PC+rel$ | - | - | - | - | - | - | - | FE | | 9 | BBC dir:b, rel | 5 | 3 | if(dir:b)=0 then PC ←PC+rel | - | - | - | - | + | - | - | B0 to B7 | | 10 | BBS dir:b, rel | 5 | 3 | $if(dir:b)=1 then PC \leftarrow PC+rel$ | - | - | - | - | + | - | - | B8 to BF | | | | | | | | | | | | | | | | 11 | JMP @A | 2 | 1 | (PC) ←(A) | - | - | - | - | - | - | - | E0 | | 12 | JMP ext | 3 | 3 | $(PC) \leftarrow ext$ | - | - | - | - | - | - | - | 21 | | 13 | CALLV #vct | 6 | 1 | vector call | - | - | - | - | - | - | - | E8 to EF | | 14 | CALL ext | 6 | 3 | subroutine call | - | - | - | - | - | - | - | 31 | | 15 | XCHW A, PC | 3 | 1 | $(PC) \leftarrow (A), (A) \leftarrow (PC)+1$ | - | - | dH | - | - | - | - | F4 | | 16 | RET | 4 | 1 | return from subroutine | - | - | - | - | - | - | - | 20 | | 17 | RETI | 6 | 1 | return from interrupt | - | - | - | | res | tore | | 30 | # **■** Other Instructions **Table B.4-4 List of Other Instructions** | No. | MNEMONIC | ~ | # | Operation | TL | TH | АН | N | Z | V | С | OP CODE | |-----|----------|---|---|--------------------------------------------------|----|----|----|---|---|---|---|---------| | 1 | PUSHW A | 4 | 1 | $((SP)) \leftarrow (A), (SP) \leftarrow (SP)-2$ | - | - | - | - | - | - | - | 40 | | 2 | POPW A | 4 | 1 | $(A) \leftarrow ((SP)), (SP) \leftarrow (SP)+2$ | - | - | dH | - | - | - | - | 50 | | 3 | PUSHW IX | 4 | 1 | $((SP)) \leftarrow (IX), (SP) \leftarrow (SP)-2$ | - | - | - | - | - | - | - | 41 | | 4 | POPW IX | 4 | 1 | $(IX) \leftarrow ((SP)), (SP) \leftarrow (SP)+2$ | - | - | - | - | - | - | - | 51 | | 5 | NOP | 1 | 1 | No operation | - | - | - | - | - | - | - | 00 | | | | | | | | | | | | | | | | 6 | CLRC | 1 | 1 | (C) ←0 | - | - | - | - | - | - | R | 81 | | 7 | SETC | 1 | 1 | (C) ←1 | - | - | - | - | - | - | S | 91 | | 8 | CLRI | 1 | 1 | (I) ←0 | - | - | - | - | - | - | - | 80 | | 9 | SETI | 1 | 1 | (I) ←1 | - | - | - | - | - | - | - | 90 | # **B.5** Instruction Map # Table B.5-1 shows the instruction map of the F<sup>2</sup>MC-8L. # ■ Instruction Map Table B.5-1 Instruction Map of the F<sup>2</sup>MC-8L | | | () | | 0 | | V | | ΔI | | () | | Ω | | V | | Ω | | _ | | =1 | | <u></u> | | | | | | <u></u> | | =1 | | <u></u> 1 | |-----|---------|------------|---------|------------|---------|------------|---------|------------|---------|------------|---------|------------|---------|----------------|---------|------------|---------|------------|---------|------------|---------|------------|---------|------------|---------|------------|---------|------------|---------|------------|---------|------------------| | ш | MOVW | A, PC | MOVW | A, SP | MOVW | A, IX | MOVW | A, EP | XCHW | A, PC | XCHW | A, SP | XCHW | A, IX | XCHW | A, EP | BNC | ē | BC | re | ВР | rel | BN | re | BNZ | re | BZ | rel | BGE | rel | BLT | rel | | Е | JMP | @ A | MOVW | SP, A | MOVW | IX, A | MOVW | EP, A | MOVW | A, #d16 | MOVW | SP, #d16 | MOVW | IX, #d16 | MOVW | EP, #d16 | CALLV | 0# | CALLV | #1 | CALLV | #2 | CALLV | #3 | CALLV | #4 | CALLV | #2 | CALLV | 9# | CALLV | #7 | | D | DECW | Α | DECW | SP | DECW | × | DECW | EP | MOVW | ext, A | MOVW | dir, A | MOVW | @IX+d, A | MOVW | @EP, A | DEC | RO | DEC | R1 | DEC | R2 | DEC | R3 | DEC | R4 | DEC | R5 | DEC | R6 | DEC | R7 | | С | INCW | А | INCW | SP | INCW | IX | INCW | EP | MOVW | A, ext | MOVW | A, dir | MOVW | A, @IX+d | MOVW | A, @EP | INC | RO | INC | R1 | INC | R2 | INC | R3 | INC | R4 | INC | R5 | INC | R6 | INC | R7 | | В | BBC dir | dir:0, rel | BBC dir | dir:1, rel | BBC dir | dir:2, rel | BBC dir | dir:3, rel | BBC dir | dir:4, rel | BBC dir | dir:5, rel | BBC dir | dir:6, rel | BBC dir | dir:7, rel | BBS dir | dir:0, rel | BBS dir | dir:1, rel | BBS dir | dir:2, rel | BBS dir | dir:3, rel | BBS dir | dir:4, rel | BBS dir | dir:5, rel | BBS dir | dir:6, rel | BBS dir | dir:7 dir:7, rel | | A | CLRB | dir:0 | CLRB | dir:1 | CLRB | dir:2 | CLRB | dir:3 | CLRB | dir:4 | CLRB | dir:5 | CLRB | dir:6 | CLRB F | dir:7 | SETB | <u>.</u> | SETB | dir:1 | SETB | dir:2 | SETB | dir:3 | SETB | dir:4 | SETB | dir:5 | SETB | dir:6 | SETB | dir:7 | | 6 | SETI | | SETC | | MOV | A, @A | MOVW | A, @A | DAS | | CMP | dir, #d8 | CMP, | #d8 @IX+d, #d8 | CMP | @EP#, d8 | CMP | R0, #d8 | CMP | R1, #d8 | CMP | R2, #d8 | CMP | R3, #d8 | CMP | R4, #d8 | CMP | R5, #d8 | CMP | R6, #d8 | CMP | R7, #d8 | | 8 | CLRI | | CLRC | | MOV | @A, T | MOVW | @A, T | DAA | | MOV | dir, #d8 | MOV, | @IX+d, #d8 | MOV | @EP#, d8 | MOV | R0, #d8 | MOV | R1, #d8 | MOV | R2, #d8 | MOV | R3, #d8 | MOV | R4, #d8 | MOV | R5, #d8 | MOV | R6, #d8 | MOV | R7, #d8 | | 7 | MOVW | A, PS | MOVW | PS, A | OR | Α | ORW | ∢ | OR | A, #d8 | OR | A, dir | OR A, | @IX+d @IX+d, | OR | A, @EP | OR | A, Ro | OR | A, R1 | OR | A, R2 | OR | A, R3 | OR | A, R4 | OR | A, R5 | OR | A, R6 | OR | A, R7 | | 9 | MOV | A, ext | MOV | ext, A | AND | A | ANDW | A | AND | A, #d8 | AND | dir | AND A, | @IX+d | AND | A, @EP | AND | A, RO | AND | A, R1 | AND | A, R2 | AND | A, R3 | AND | A, R4 | AND | A, R5 | AND | A, R6 | AND | A, R7 | | 5 | POPW | Α | POPW | X | XOR | Α | XORW | A | XOR | A, #d8 | XOR | A, dir | XOR A, | @IX+d | XOR | A, @EP | XOR | A, RO | XOR | A, R1 | XOR | A, R2 | XOR | A, R3 | XOR | A, R4 | XOR | A, R5 | XOR | A, R6 | XOR | A, R7 | | 4 | PUSHW | А | PUSHW | IX | нох | A, T | XCHW | A, T | / | | MOV | dir, A | NOM | @IX+d@IX+d, A | MOV | @EP, A | MOV | R0, A | MOV | R1, A | MOV | R2, A | MOV | R3, A | MOV | R4, A | MOV | R5, A | MOV | R6, A | MOV | R7. A | | 3 | RETI | | CALL | addr16 | SUBC | А | SUBCW | A | SUBC | A, #d8 | SUBC | A, dir | SUBC A, | | SUBC | A, @EP | SUBC | A, RO | SUBC | A, R1 | SUBC | A, R2 | SUBC | A, R3 | SUBC | A, R4 | SUBC | A, R5 | SUBC | A, R6 | SUBC | A, R7 | | 2 | RET | | JMP | addr16 | ADDC | A | ADDCW | A | ADDC | A, #d8 | ADDC | A, dir | ADDC A, | @IX+d | ADDC | A, @EP A, | ADDC | A, RO | ADDC | A, R1 | ADDC | A, R2 | ADDC | A, R3 | ADDC | A, R4 | ADDC | A, R5 | ADDC | A, R6 | ADDC | A, R7 | | 1 | SWAP | | DVIO | Α | CMP | A | CMPW | A | CMP | A, #d8 | CMP | A, dir | CMP A, | @IX+d | CMP | A, @EP | CMP | A, R0 | CMP | A, R1 | CMP | A, R2 | CMP | A, R3 | CMP | A, R4 | CMP | A, R5 | CMP | A, R6 | CMP | A, R7 | | 0 | NOP | | ппи | Α | ROLC | A | RORC | ∢ | MOV | A, #d8 | MOV | A, dir | MOV A, | @IX+d | MOV | A, @EP | MOV | A, RO | MOV | A, R1 | MOV | A, R2 | MOV | A, R3 | MOV | A, R4 | MOV | A, R5 | MOV | A, R6 | MOV | A, R7 | | Ξ/. | _ | , | _ | - | ٥ | 7 | ď | , | 4 | - | Ц | 0 | ď | 0 | 7 | | 0 | ٥ | o | 0 | < | ζ. | α | ַ | ( | ر | ٥ | _ | Ц | , | Ц | - | # **APPENDIX C** Mask Options ## Table C-1 lists the mask options of the MB89202/F202RA series. ## **■** Mask Options ### **Table C-1 Mask Options** | No. | Part number | MB89202 | MB89F202/F202RA | MB89V201 | | | |-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------------------|-------------------------------------------|--|--| | | Specifying procedure | Specify when ordering masking | Specify by part number | | | | | 1 | Selection of initial value of main clock oscillation settling time* (with $F_{CH} = 12.5 \text{ MHz}$ ) $01:2^{14}/F_{CH}$ (Approx.1.31 ms) $10:2^{17}/F_{CH}$ (Approx.10.5 ms) $11:2^{18}/F_{CH}$ (Approx.21.0 ms) | Selectable | Fixed to 2 <sup>18</sup> /F <sub>CH</sub> | Fixed to 2 <sup>18</sup> /F <sub>CH</sub> | | | | 2 | Reset pin output With reset output Without reset output | Selectable | With reset output | With reset output | | | | 3 | Power on reset selection<br>With power-on reset<br>Without power-on reset | Selectable | With power-on reset | With power-on reset | | | F<sub>CH</sub>: Main clock scillation frequency <sup>\*:</sup> Initial value to which the oscillation settling time bit (SYCC: WT1, WT0) in the system clock control register is set # APPENDIX D Programming EPROM with Evaluation Chip This section describes how to program EPROM with evaluation chip. ### ■ Programming EPROM with Evaluation Chip #### EPROM for use 32 Kbyte EPROM (equivalent to MBM27C256A DIP-28) In normal operation (Corresponding address on the ROM programmer) mode 0000<sub>H</sub> I/O 0080н RAM 512bytes 0280<sub>H</sub> Unavailable 8000<sub>H</sub> > 0000н Program area Program area (PROM 32Kbytes) (PROM 32Kbytes) FFFF<sub>H</sub> > 7FFF<sub>H</sub> Figure D-1 Memory Map of the Evaluation Chip #### Programming EPROM - 1. Make the MBM27C256-equivalent setting for the EPROM programmer - 2. Load the program data to the area from $0000_{\rm H}$ to $7{\rm FFF}_{\rm H}$ of the EPROM programmer. - 3. Program the area from $0000_H$ to $7FFF_H$ with the EPROM programmer. # APPENDIX E Pin State of the MB89202/F202RA Series Table E-1 describes the pin states in each operation mode of the MB89202/F202RA series. #### ■ Pin States in Each Operation Mode Table E-1 Pin States in Each Operation Mode | Pin name | In normal operation mode | In sleep<br>mode | In stop mode<br>(SPL = 0) | In stop mode<br>(SPL = 1) | During a reset | |----------------------------------|--------------------------|--------------------|---------------------------|---------------------------|--------------------| | X0 | Oscillation input | Oscillation input | Hi-Z | Hi-Z | Oscillation input | | X1 | Oscillation output | Oscillation output | "H" output | "H" output | Oscillation output | | P00/INT20/AN4<br>to<br>P07/INT27 | Port I/O or resource I/O | Hold | Hold | Hi-Z *1,*2 | Hi-Z | | P30/UCK/SCK<br>to<br>P37/BZ/PPG | Port I/O or resource I/O | Hold | Hold | Hi-Z *1,*2 | Hi-Z | | P40/AN0<br>to<br>P43/AN3 | Port I/O or resource I/O | Hold | Hold | Hi-Z *2 | Hi-Z | | P50/PWM | Port I/O or resource I/O | Hold | Hold | Hi-Z *2 | Hi-Z | | P60, P61 | Port I/O | Hold | Hold | Hi-Z *2 | Hi-Z | | P70 to P72 | Port I/O | Hold | Hold | Hi-Z *2 | Hi-Z | <sup>\*1:</sup> For port input and peripheral input, the internal input level is fixed to prevent them from generating a leak via the input open. However, if external interrupts are allowed for P00 to P07 and P34 to P36, only the external interrupts are available as their inputs. <sup>\*2:</sup> The pins, for which pull-up is selected by the option setting, enter the pull-up state. Hi-Z: Indicates high impedance. Hold: The pins, for which output is set, maintain the pin state (level) just before the mode transition. SPL: Pin state spacification bit of the standby control register (STBC) The index follows on the next page. This is listed in alphabetic order. # Index | Numerics | Notes on Using the 8/16-bit Capture | |---------------------------------------------------------------------------------------|-----------------------------------------------------------| | 12-bit PPG 12-bit PPG Function | Timer/Counter | | 12-bit PPG Control Register 3 (RCR23) | 8-bit PWM Timer Block Diagram of an 8-bit PWM Timer | | Example of Operations of 12-bit PPG Timer Functions 219 Functions of 12-bit PPG Timer | Pin Related to the 8-bit PWM Timer | | 8/16-bit Capture Timer/Counter of Interrupts | 8-bit Serial Input Program Example for 8-bit Serial Input | | A | В | |-----------------------------------------------------|------------------------------------------------------| | A/D Control Register | Behavior | | A/D Control Register 1 (ADC1) | Behavior under the Flash Security Feature372 | | A/D Control Register 2 (ADC2)268 | Bidirectional Serial I/O Operation | | A/D Conversion | When Bidirectional Serial I/O Operation is Performed | | A/D Conversion Functions | 334 | | Interrupt when A/D Conversion Functions are Enabled | Bit Manipulation | | 272 | Read Destination at Execution of a Bit Manipulation | | Operations of A/D Conversion Functions 274 | Instruction391 | | Program Example of the A/D Conversion Functions | Bits | | 277 | Bits for Controlling Acceptance of Interrupts | | A/D Converter | 30 | | Activating the A/D Converter Functions 273 | Bits for Indicating Arithmetic Operation Results | | Block Diagram of the A/D Converter261 | 29 | | Block Diagram of the Pins Related to the A/D | Block Diagram | | Converter | Block Diagram for 8/16-bit Capture Timer/Counter | | Notes on Using the A/D Converter275 | Pins | | Pins Related to the A/D Converter | Block Diagram for 8-bit Serial I/O Pins318 | | Register and Vector Table Related to the Interrupt | Block Diagram of 12-bit PPG Timer209 | | of the A/D Converter272 | Block Diagram of 8/16-bit Capture Timer/Counter | | Registers Related to the A/D Converter265 | 166 | | A/D Data Register | Block Diagram of 8-bit Serial I/O315 | | A/D Data Register (ADDH and ADDL) 270 | Block Diagram of an 8-bit PWM Timer139 | | A/D Enable Register | Block Diagram of Circuitry Terminating at the Pin | | A/D Enable Register (ADEN)271 | Associated with the 12-bit PPG Timer | | Abstract | 212 | | Abstract 372 | Block Diagram of Circuitry Terminating at the Pins | | Activating | Associated with External Interrupt | | Activating the A/D Converter Functions | Circuit 1230 | | Active Mode | Block Diagram of Circuitry Terminating at the Pins | | Operations in Active Mode59 | Associated with External Interrupt Circuit 2 | | ADC | 247 | | A/D Control Register 1 (ADC1) | Block Diagram of Clock Controller54 | | A/D Control Register 2 (ADC2) | Block Diagram of External Interrupt Circuit 1 | | ADDH and ADDL | 227 | | A/D Data Register (ADDH and ADDL) | Block Diagram of External Interrupt Circuit 2 | | | 245 | | Address Comparison EN Register | Block Diagram of External Reset Pin47 | | Address Comparison EN Register (WREN) 354 | Block Diagram of MB89202/F202RA Series | | Addressing | Block Diagram of Port 0 | | Explanation on Addressing | Block Diagram of Port 3 | | ADEN | Block Diagram of Port 491 Block Diagram of Port 595 | | A/D Enable Register (ADEN)271 | Block Diagram of Port 6101 | | Association | Block Diagram of Port 7 | | Association between the Interrupt Enable Bits for | Block Diagram of the A/D Converter261 | | External Interrupt Circuit 2 and the External | Block Diagram of the Buzzer Output341 | | Interrupt Pins248 | Block Diagram of the Pin Related to the 8-bit PWM | | Automatic Erasing | Timer141 | | Automatic Erasing363 | Block Diagram of the Pin Related to the Buzzer | | Automatic Write/Erase | Output342 | | Automatic Write/Erase 364, 365, 366 | Block Diagram of the Pins Related to the A/D | | | Converter264 | | | Block Diagram of the UART-relating Pins | | | 288 | | Block Diagram of the Wild Register Function | External Interrupt Circuit 1 Programming Example | |-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------| | 349 | 241 | | Block Diagram of Time-base Timer118 | Functions of External Interrupt Circuit 1 226 | | Block Diagram of UART284 | Functions of External Interrupt Circuit 2 | | Block Diagram of Watchdog Timer129 | (Level Detection)244 | | Branch | I/O Circuit Types | | Branch Instructions397 | Interrupt during the Operation of External Interrupt | | Buzzer Output | Circuit 1237 | | Block Diagram of the Buzzer Output341 | Interrupt during the Operation of External Interrupt | | Block Diagram of the Pin Related to the Buzzer | Circuit 2 | | Output342 | Operation of External Interrupt Circuit 1 | | Buzzer Output Function340 | Operation of External Interrupt Circuit 2 254 | | Program Example for Buzzer Output345 | Pins Associated with External Interrupt Circuit 1 | | Buzzer Register | 229 | | Buzzer Register (BZCR)343 | Pins Associated with External Interrupt Circuit 2 | | BZCR | 246 | | Buzzer Register (BZCR)343 | Program Example for External Interrupt Circuit 2 | | | 256 | | С | Register Associated with Interrupt Generation by | | | External Interrupt Circuit 1 and Vector | | Cancellation | Table | | Cancellation of Standby Mode by an Interrupt | Register Associated with Interrupt Generation by | | 70 | External Interrupt Circuit 2 and Vector Table253 | | Capture | Registers Associated with External Interrupt Circuit 1 | | Capture Function Operation193 | 231 | | Capture Control Register | Registers Associated with External Interrupt Circuit 2 | | Capture Control Register (TCCR)171 | 249 | | Capture Data Registers | Circuitry Terminating | | Capture Data Registers H and L (TCPH and TCPL) | , | | 182 | Block Diagram of Circuitry Terminating at the Pin<br>Associated with the 12-bit PPG Timer | | Capture Timer/Counter | 212 | | Registers of 8/16-bit Capture Timer/Counter 170 | Block Diagram of Circuitry Terminating at the Pins | | CCR | Associated with External Interrupt Circuit 1 | | Configuration of the Condition Code Register (CCR) | 230 | | 29 | Block Diagram of Circuitry Terminating at the Pins | | Changing Edge Polarity Selection | Associated with External Interrupt Circuit 2 | | Exercise Caution when Changing Edge Polarity | 247 | | Selection238 | Clock Controller | | Choice | Block Diagram of Clock Controller 54 | | Choice of the Transfer Clock Rate281 | Clock Divider Selection Register | | | Clock Divider Selection Register (UPC) 299 | | Circuit | | | Association between the Interrupt Enable Bits for | Clock Generator Clock Generator | | External Interrupt Circuit 2 and the External Interrupt Pins | | | * | Clock Mode | | Block Diagram of Circuitry Terminating at the Pins Associated with External Interrupt Circuit 1 | Operations in Each Clock Mode 58 | | Associated with External Interrupt Circuit 1 | Clock Speed Switching | | Block Diagram of Circuitry Terminating at the Pins | Gears (Clock Speed Switching Function) 58 | | Associated with External Interrupt Circuit 2 | Clock Supply | | Associated with External Interrupt Circuit 2 | Clock Supply Function116 | | Block Diagram of External Interrupt Circuit 1 | Clock Supply Map51 | | Block Diagram of External Interrupt Circuit 1 | Operations of Clock Supply Function 122 | | Block Diagram of External Interrupt Circuit 2 | CNTR | | 245 | PWM Control Register (CNTR)143 | | | | | Command Sequence | E | |--------------------------------------------------------|------------------------------------------------------| | Command Sequence Table | EIC | | COMR | External Interrupt Control Register 1 (EIC1) | | PWM Compare Register (COMR)145 | 232 | | Condition Code Register | External Interrupt Control Register 2 (EIC2) | | Configuration of the Condition Code Register (CCR) | 005 | | 29 | | | Configuration | EIE | | Configuration of Memory Space22 | External Interrupt Circuit 2 Control Register (EIE2) | | Configuration of the Condition Code Register (CCR) | 250 | | | EIF | | Configuration of the Coneral purpose Pagisters | External Interrupt 2 Flag Register (EIF2)252 | | Configuration of the General-purpose Registers32 | Erase | | Configuration of the Interrupt Level Setting Registers | Automatic Write/Erase364, 365, 366 | | | Detailed Explanation of Flash Memory Write/Erase | | (ILR1 to ILR4) | 367 | | Configuration of the Register Bank Pointer (RP) | Erasing | | Configuration of the Poset Flor Posister (PSEP) | Automatic Erasing363 | | Configuration of the Reset Flag Register (RSFR) | Erasing All Data (Erasing Chips)371 | | | Writing to/Erasing Flash Memory358 | | Configuration of the System Clock Control Register | Erasing All Data | | (SYCC) | Erasing All Data (Erasing Chips)371 | | Dedicated Register Configuration | | | Controlling Acceptance | Erasing Chips | | Bits for Controlling Acceptance of Interrupts | Erasing All Data (Erasing Chips)371 | | 30 | Evaluation Chip | | Counter | Programming EPROM with Evaluation Chip | | Counter Function | 401 | | Counter Function Operation | Example | | Program Example of Counter Function 202 | Example of Operations of 12-bit PPG Timer Functions | | CPU Reads | 219 | | States of Pins after the CPU Reads the Mode Data | Exercise Caution | | 50 | Exercise Caution when Changing Edge Polarity | | | Selection238 | | D | Explanation | | | Explanation on Addressing | | Data Setting Register | Explanation on the Codes Representing Instructions | | Data Setting Register (WRDR)351 | | | DDR | Explanation on the Items of Instructions'List | | Registers of Port 491 | 382 | | Registers of Port 595 | External Interrupt | | Registers PDR0, DDR0, and PUL0 of Port 0 79 | Association between the Interrupt Enable Bits for | | Registers PDR3, DDR3, and PUL3 of Port 3 85 | External Interrupt Circuit 2 and the External | | Registers PDR6, DDR6, and PUL6 of Port 6 102 | Interrupt Pins248 | | Registers PDR7, DDR7, and PUL7 of Port 7 108 | Block Diagram of Circuitry Terminating at the Pins | | Detailed Explanation | Associated with External Interrupt Circuit 1 | | Detailed Explanation of Flash Memory Write/Erase | Associated with External Interrupt Circuit 1 | | | Block Diagram of Circuitry Terminating at the Pins | | Diagram | · · · · · · · · · · · · · · · · · · · | | Diagram for State Transition in Standby Mode | Associated with External Interrupt Circuit 2 | | Biagram for State Transition in Standby Wode 68 | Plack Diagram of Evternal Interrunt Circuit 1 | | DIP-32P-M06 | Block Diagram of External Interrupt Circuit 1 | | | Plack Diagram of Evternal Interrupt Circuit 2 | | Package Dimension of DIP-32P-M06 | Block Diagram of External Interrupt Circuit 2 | | 1 III ASSIGNMENT OF DIF-32F-MOO0 | Functions of External Interrupt Circuit 1226 | | | r unctions of External interrupt Circuit 1220 | | Functions of External Interrupt Circuit 2 | Program Access to Flash Memory | |----------------------------------------------------------|----------------------------------------------------| | (Level Detection)244 | Writing to the Flash Memory | | Interrupt during the Operation of External Interrupt | Writing to/Erasing Flash Memory358 | | Circuit 1237 | Flash Memory Control Status Register | | Interrupt during the Operation of External Interrupt | Flash Memory Control Status Register (FMCS) | | Circuit 2253 | 359 | | Operation of External Interrupt Circuit 1239 | Flash Memory Register | | Operation of External Interrupt Circuit 2254 | Flash Memory Register358 | | Pins Associated with External Interrupt Circuit 1 | Flash Security | | 229 | Behavior under the Flash Security Feature 372 | | Pins Associated with External Interrupt Circuit 2 | How to disable the Flash Security Feature 372 | | 246 | How to enable the Flash Security Feature 372 | | Program Example for External Interrupt Circuit 2 | FMCS | | 256 | Flash Memory Control Status Register (FMCS) | | Register Associated with Interrupt Generation by | | | External Interrupt Circuit 1 and Vector | | | Table238 | FPT-34P-M03 | | Register Associated with Interrupt Generation by | Package Dimension of FPT-34P-M0311 | | External Interrupt Circuit 2 and Vector | Pin Assignment of FPT-34P-M039 | | Table253 | Function | | Registers Associated with External Interrupt Circuit 1 | Function of the External Reset Pin47 | | 231 | Functions of 12-bit PPG Timer | | Registers Associated with External Interrupt Circuit 2 | Functions of External Interrupt Circuit 1 | | 249 | Functions of External Interrupt Circuit 2 | | External Interrupt 2 Flag Register | (Level Detection)244 | | External Interrupt 2 Flag Register (EIF2)252 | Functions of I/O Ports | | External Interrupt Circuit | Functions of Port 0 Registers | | External Interrupt Circuit 1 Programming Example | Functions of Port 3 Registers | | 241 | Functions of Port 5 Registers | | External Interrupt Circuit 2 Control Register | Functions of Port 6 Registers | | External Interrupt Circuit 2 Control Register (EIE2) | Functions of Port 7 Registers 109 | | 250 | Functions of the Dedicated Register | | External Interrupt Control Register | Functions of UART280 | | External Interrupt Control Register 1 (EIC1) | | | 232 | G | | External Interrupt Control Register 2 (EIC2) | Gears | | 235 | Gears (Clock Speed Switching Function) 58 | | External Reset | General-purpose Register | | | Configuration of the General-purpose Registers | | Block Diagram of External Reset Pin | Configuration of the General-purpose Registers | | | Features of the General-purpose Registers | | External Shift Clock | | | When the External Shift Clock is Used331 | General-purpose Register Area | | _ | General-purpose Register Area | | F | (Address: 0100 <sub>H</sub> to 01FF <sub>H</sub> ) | | F <sup>2</sup> MC-8L | | | Overview of the Instructions of the F <sup>2</sup> MC-8L | Н | | 380 | Halfway Stop | | Features | Operation in Standby Mode and at Halfway Stop | | Features of MB89202/F202RA Series2 | 197 | | | Hardware Reset | | Flash Content Protection | Input of a Hardware Reset (RST) | | Flash Content Protection | _ | | Flash Memory | Hardware Sequence | | Detailed Explanation of Flash Memory Write/Erase | Hardware Sequence Flags | | 367 | | | Flash Memory Features358 | | | High voltage | Internal Shift Clock | |----------------------------------------------------------|--------------------------------------------------------| | High voltage supply on RST pin | When the Internal Shift Clock is Used329 | | (applicable to MB89F202RA only) | Interrupt | | 358 | 8/16-bit Capture Timer/Counter of Interrupts | | Higher Address Set Register | 183 | | Higher Address Set Register (WRARH)352 | Association between the Interrupt Enable Bits for | | How to | External Interrupt Circuit 2 and the External | | How to disable the Flash Security Feature 372 | Interrupt Pins248 | | How to enable the Flash Security Feature 372 | Bits for Controlling Acceptance of Interrupts30 | | • | Block Diagram of Circuitry Terminating at the Pins | | I | Associated with External Interrupt Circuit 1 | | | 230 | | I/O | Block Diagram of Circuitry Terminating at the Pins | | 8-bit Serial I/O Interrupt Register and Vector Table | Associated with External Interrupt Circuit 2 | | 324 | 247 | | Block Diagram for 8-bit Serial I/O Pins | Block Diagram of External Interrupt Circuit 1 | | Block Diagram of 8-bit Serial I/O | 227 | | Functions of I/O Ports | Block Diagram of External Interrupt Circuit 2 | | I/O Circuit Types | 245 | | I/O Map | Cancellation of Standby Mode by an Interrupt | | I/O Port Programming Example | 70 | | Interrupt at Serial I/O Operation | Configuration of the Interrupt Level Setting Registers | | Notes on Using 8-bit Serial I/O | (ILR1 to ILR4) | | Registers of 8-bit Serial I/O | External Interrupt 2 Flag Register (EIF2)252 | | Serial I/O Function | External Interrupt Circuit 1 Programming Example | | When Bidirectional Serial I/O Operation is Performed | External Interment Circuit 2 Control Register (EEC) | | | External Interrupt Circuit 2 Control Register (EIE2) | | ILR | External Interrupt Control Register 1 (EIC1) | | Configuration of the Interrupt Level Setting Registers | 232 | | (ILR1 to ILR4)36 | External Interrupt Control Register 2 (EIC2) | | Indicating Arithmetic Operation Results | 235 | | Bits for Indicating Arithmetic Operation Results | Functions of External Interrupt Circuit 1226 | | 29 | Functions of External Interrupt Circuit 2 | | Influence | (Level Detection)244 | | Influence from a Reset of Contents in RAM 49 | Interrupt at Serial I/O Operation324 | | | Interrupt during the Operation of External Interrupt | | Input Input of a Handman Posset (DST) 272 | Circuit 1237 | | Input of a Hardware Reset (RST) | Interrupt during the Operation of External Interrupt | | Instruction | Circuit 2253 | | Branch Instructions | Interrupt Processing Time40 | | Explanation on the Codes Representing Instructions | Interrupt when A/D Conversion Functions are Enabled | | | 272 | | Explanation on the Items of Instructions'List | Interrupts when the Interval Timer Function is | | | Enabled121 | | Instruction Map | Interrupts while Interval Timer Functions are Enabled | | Operation Instructions | 147 | | Overview of the Instructions of the F <sup>2</sup> MC-8L | Multiple Interrupts39 | | | Operation of External Interrupt Circuit 1239 | | Read Destination at Execution of a Bit Manipulation | Operation of External Interrupt Circuit 2254 | | Instruction | Oscillation Stabilization Time and Time-base Timer | | Special Instructions | Interrupts | | Transfer Instructions | Pins Associated with External Interrupt Circuit 1 | | Instruction Cycle | Ding Associated with Eutomal Intermet Cinvit 2 | | Instruction Cycle (t <sub>INST</sub> )57 | Pins Associated with External Interrupt Circuit 2 | | Instruction Cycle (INST) | 246 | | Program Example for External Interrupt Circuit 2 | L | |---------------------------------------------------------|-----------------------------------------------------| | 256 | Level Detection | | Reception Interrupt303 | Functions of External Interrupt Circuit 2 | | Register and Vector Table Related to 8/16-bit Capture | (Level Detection)244 | | Timer/Counter of Interrupts184 | Lower Address Set Register | | Register and Vector Table Related to Interrupts from | <del>_</del> | | Time-base Timer121 | Lower Address Set Register (WRARL)353 | | Register and Vector Table Related to the Interrupt of | •• | | the A/D Converter272 | M | | Register and Vector Table Related to the Interrupts of | Mask | | an 8-bit PWM Timer147 | Mask Options400 | | Register Associated with Interrupt Generation by | MB89202/F202RA | | External Interrupt Circuit 1 and Vector | Block Diagram of MB89202/F202RA Series7 | | Table238 | Features of MB89202/F202RA Series | | Register Associated with Interrupt Generation by | MB89202/F202RA Series Models 4 | | External Interrupt Circuit 2 and Vector | | | Table253 | Memory Access | | Registers Associated with External Interrupt Circuit 1 | Operations for Selecting Memory Access Mode | | 231 | 72 | | Registers Associated with External Interrupt Circuit 2 | Memory Map | | 249 | Memory Map | | Stack Area for Interrupt Processing42 | Memory Space | | Stack Operation at the Beginning of Interrupt | Configuration of Memory Space22 | | Processing41 | Mode | | Stack Operation at the End of Interrupt Processing | Cancellation of Standby Mode by an Interrupt | | 41 | 70 | | Steps in the Interrupt Operation37 | Diagram for State Transition in Standby Mode | | Transition to Standby Mode and Interrupt70 | 68 | | Transmission Interrupt303 | Mode Data72 | | UART Interrupt Related Registers and Vector Table | Mode Fetch | | Addresses | Notes on Setting Standby Mode70 | | Interrupt Enable Bits | Operation in Standby Mode and at Halfway Stop | | Association between the Interrupt Enable Bits for | 197 | | External Interrupt Circuit 2 and the External | Operations for Selecting Memory Access Mode | | Interrupt Pins248 | 72 | | Interrupt Level Setting Registers | Operations in Active Mode59 | | Configuration of the Interrupt Level Setting Registers | Operations in Each Clock Mode 58 | | (ILR1 to ILR4)36 | Operations in Standby Mode | | Interrupt Requests | Operations in the Standby Mode and at a Suspension | | Interrupt Requests from Peripheral Functions34 | 152 | | Interval Timer | Operations Related to Sleep Mode64 | | | Operations Related to Stop Mode65 | | Interrupts when the Interval Timer Function is Enabled | Pin States in Each Operation Mode | | | Reception Operations (Operating Mode 0,1,or 3) | | Interrupts while Interval Timer Functions are Enabled | 307 | | | Reception Operations (Operating Mode 2 Only) | | , | | | Interval Timer Function Operation | Single-chip Mode72 | | Interval Timer Functions (Functions to Output | States of Pins after the CPU Reads the Mode Data | | the Square Wave) | 50 | | Operations of Interval Timer Function | Theory of Operation for Operating Mode 0,1,2, and 3 | | (Time-base Timer) | 305 | | Operations of the Interval Timer Functions148 | Transition to Standby Mode and Interrupt | | Program Example of Interval Timer Function | Transmission Operations in Operating Mode is | | 200 | 0,1,2,or 3 | | Program Example of Interval Timer Functions | | | 15/ | | | Multiple Interrupts | Operations in Standby Mode63 | |------------------------------------------------------|----------------------------------------------------------| | Multiple Interrupts39 | Operations in the Standby Mode and at a Suspension | | | 152 | | N | Operations of A/D Conversion Functions274 | | Notes | Operations of Clock Supply Function122 | | Notes | Operations of Interval Timer Function | | Notes on Setting Standby Mode70 | (Time-base Timer)122 | | Notes on Using 12-bit PPG Timer | Operations of the 8-bit PWM Timer Functions | | Notes on Using 8-bit PWM Timer | 150 | | Notes on Using 8-bit Serial I/O | Operations of the Interval Timer Functions148 | | Notes on Using the 8/16-bit Capture Timer/Counter | Operations of Time-base Timer122 | | 198 | Operations of Watchdog Timer131 | | Notes on Using the A/D Converter | Operations Related to Sleep Mode64 | | Notes on Using Time-base Timer | Operations Related to Stop Mode65 | | Notes on Using Watchdog Timer | Overview of the Reset Operation48 | | | Pin States in Each Operation Mode402 | | 0 | Read-modify-write Operation391 | | On another Marks | Reception Operations (Operating Mode 0,1,or 3) | | Operating Mode | 307 | | Reception Operations (Operating Mode 0,1,or 3) | Reception Operations (Operating Mode 2 Only) | | | 309 | | Reception Operations (Operating Mode 2 Only) | Serial Input Operation327 | | | Serial Output Operation325 | | Theory of Operation for Operating Mode 0,1,2, and 3 | Stack Operation at the Beginning of Interrupt | | 305 | Processing41 | | Transmission Operations in Operating Mode is | Stack Operation at the End of Interrupt Processing | | 0,1,2,or 3306 | 41 | | Operation | Steps in the Interrupt Operation37 | | Bits for Indicating Arithmetic Operation Results | | | 29 | Theory of Operation for Operating Mode 0,1,2, and 3 | | Capture Function Operation | 305 | | Counter Function Operation | Transmission Operations in Operating Mode is | | Example of Operations of 12-bit PPG Timer Functions | 0,1,2,or 3306 | | 219 | When Bidirectional Serial I/O Operation is Performed | | Interrupt at Serial I/O Operation324 | 334 | | Interrupt during the Operation of External Interrupt | Operation Order | | Circuit 1237 | Operation Order of the Wild Register Function | | Interrupt during the Operation of External Interrupt | 356 | | Circuit 2 | Oscillation Stabilization Wait Time | | Interval Timer Function Operation | Oscillation Stabilization Time and Time-base Timer | | Operation at Serial Input Completion | Interrupts121 | | Operation at Serial Output Completion | Oscillation Stabilization Wait Time60, 71 | | Operation in Standby Mode and at Halfway Stop | Reset Sources and Oscillation Stabilization Wait Time | | 197 | 44 | | Operation Instructions | Other | | Operation of External Interrupt Circuit 1 239 | Other Instructions | | Operation of External Interrupt Circuit 2 254 | Others372 | | Operation of Port 082 | OUT | | Operation of Port 388 | Registers of Port 491 | | Operation of Port 493 | Overview | | Operation of Port 5 | Overview of the Instructions of the F <sup>2</sup> MC-8L | | Operation of Port 6105 | 380 | | Operation of Port 7111 | Overview of the Reset Operation48 | | Operations for Selecting Memory Access Mode | Overview of the Reset Operation40 | | 72 | | | Operations in Active Mode 59 | | | Operations in Each Clock Mode 58 | | | P | Structure of Port 3 | . 84 | |-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|------| | P37/BZ/PPG | Port 4 | | | P37/BZ/PPG Pin342 | Block Diagram of Port 4 | | | Package Dimension | Operation of Port 4 | | | Package Dimension of DIP-32P-M0610 | Pins of Port 4 | | | Package Dimension of FPT-34P-M0311 | Registers of Port 4 | | | PDR | Structure of Port 4 | . 90 | | Registers of Port 491 | Port 5 | | | Registers of Port 5 | Block Diagram of Port 5 | | | Registers PDR0, DDR0, and PUL0 of Port 079 | Functions of Port 5 Registers | | | Registers PDR3, DDR3, and PUL3 of Port 385 | Operation of Port 5 | | | Registers PDR6, DDR6, and PUL6 of Port 6102 | Pins of Port 5 | | | Registers PDR7, DDR7, and PUL7 of Port 7 108 | Registers of Port 5 | | | - | Structure of Port 5 | . 94 | | Peripheral Function | Port 6 | | | Interrupt Requests from Peripheral Functions | Block Diagram of Port 6 | 101 | | 34 | Functions of Port 6 Registers | 103 | | Pin | Operation of Port 6 | 105 | | Pin Associated with the 12-bit PPG Timer211 | Pins of Port 6 | 100 | | Pin Related to the 8-bit PWM Timer141 Pins Associated with External Interrupt Circuit 1 | Registers PDR6, DDR6, and PUL6 of Port 6 | 102 | | 229 | Structure of Port 6 | | | Pins Associated with External Interrupt Circuit 2 | Port 7 | | | 246 | Block Diagram of Port 7 | 1∩Ω | | Pins of 8/16-bit Capture Timer/Counter168 | Functions of Port 7 Registers | | | Pins of 8-bit Serial I/O317 | Operation of Port 7 | | | Pins of Port 0 | Pins of Port 7 | | | Pins of Port 384 | Registers PDR7, DDR7, and PUL7 of Port 7 | 107 | | Pins of Port 490 | Registers I DR7, DDR7, and I OL7 of Fort | 108 | | Pins of Port 594 | Structure of Port 7 | | | Pins of Port 6100 | | 101 | | Pins of Port 7107 | PPG Timer | | | Pins Related to the A/D Converter263 | Block Diagram of Circuitry Terminating at the Pin<br>Associated with the 12-bit PPG Timer | n | | Pin Assignment | Associated with the 12-bit PPG Timer | 212 | | Pin Assignment of DIP-32P-M068 | | 212 | | Pin Assignment of FPT-34P-M039 | Precautions | 4.0 | | Pin Function | Precautions on Handling Devices | | | Pin Functions Description12 | Precautions when Selecting a Model | 6 | | Pin States | Program Access | | | Pin States in Each Operation Mode402 | Program Access to Flash Memory | 373 | | Port | Program Example | | | Functions of I/O Ports76 | Program Example for 12-bit PPG Timer | 223 | | I/O Port Programming Example | Program Example for 8-bit Serial Input | 337 | | | Program Example for 8-bit Serial Output | 336 | | Port 0 | Program Example for Buzzer Output | 345 | | Block Diagram of Port 0 | Program Example for External Interrupt Circuit 2 | | | Functions of Port 0 Registers80 | | 256 | | Operation of Port 082 | Program Example for UART | 311 | | Pins of Port 0 | Program Example of Counter Function | 202 | | Registers PDR0, DDR0, and PUL0 of Port 079 | Program Example of Interval Timer Function | 200 | | Structure of Port 0 | Program Example of Interval Timer Functions | | | Port 3 | | 157 | | Block Diagram of Port 385 | Program Example of PWM Timer Functions | | | Functions of Port 3 Registers86 | | 159 | | Operation of Port 388 | Program Example of the A/D Conversion Functio | ns | | Pins of Port 3 | | 277 | | Registers PDR3, DDR3, and PUL3 of Port 385 | | | | Programming EPROM | 12-bit PPG Control Register 2 (RCR22)21 | |-----------------------------------------------------|-------------------------------------------------------| | Programming EPROM with Evaluation Chip | 12-bit PPG Control Register 3 (RCR23)21 | | 401 | 12-bit PPG Control Register 4 (RCR24)21 | | Programming Example | 8-bit Serial I/O Interrupt Register and Vector Table | | External Interrupt Circuit 1 Programming Example | 32 | | 241 | A/D Control Register 1 (ADC1)26 | | Programming Examples for Time-base Timer | A/D Control Register 2 (ADC2)26 | | 125 | A/D Data Register (ADDH and ADDL)27 | | Programming Examples of Watchdog Timer | A/D Enable Register (ADEN)27 | | 133 | Address Comparison EN Register (WREN)35 | | PUL | Block Diagram of the Wild Register Function | | Registers of Port 595 | 34 | | Registers PDR0, DDR0, and PUL0 of Port 0 79 | Buzzer Register (BZCR)34 | | Registers PDR3, DDR3, and PUL3 of Port 3 85 | Capture Control Register (TCCR)17 | | Registers PDR6, DDR6, and PUL6 of Port 6 102 | Capture Data Registers H and L (TCPH and TCPL) | | Registers PDR7, DDR7, and PUL7 of Port 7 108 | 18 | | PWM Compare Register | Clock Divider Selection Register (UPC)29 | | PWM Compare Register (COMR) 145 | Configuration of the Condition Code Register (CCR | | | 2 | | PWM Control Register | Configuration of the General-purpose Registers | | PWM Control Register (CNTR) | 3 | | PWM Timer | Configuration of the Interrupt Level Setting Register | | Program Example of PWM Timer Functions | (ILR1 to ILR4)3 | | | Configuration of the Register Bank Pointer (RP) | | PWM Timer Functions | 3 | | | Configuration of the Reset Flag Register (RSFR) | | R | 4 | | RAM | Configuration of the System Clock Control Register | | 16-bit Data Storage State on RAM26 | (SYCC)5 | | Influence from a Reset of Contents in RAM 49 | Data Setting Register (WRDR)35 | | RCR | Dedicated Register Configuration2 | | 12-bit PPG Control Register 1 (RCR21)214 | External Interrupt 2 Flag Register (EIF2)25 | | 12-bit PPG Control Register 2 (RCR22) | External Interrupt Circuit 2 Control Register (EIE2) | | 12-bit PPG Control Register 3 (RCR23) | 25 | | 12-bit PPG Control Register 4 (RCR24) | External Interrupt Control Register 1 (EIC1) | | | 23 | | Read | External Interrupt Control Register 2 (EIC2) | | Setting the Read/Reset State | 23 | | States of Pins after the CPU Reads the Mode Data | Features of the General-purpose Registers3 | | 50 | Flash Memory Control Status Register (FMCS) | | Read Destination | 35 | | Read Destination at Execution of a Bit Manipulation | Flash Memory Register35 | | Instruction391 | Functions of Port 0 Registers8 | | Read-modify-write | Functions of Port 3 Registers8 | | Read-modify-write Operation391 | Functions of Port 5 Registers9 | | Receiving Status | Functions of Port 6 Registers10 | | Receiving Status | Functions of Port 7 Registers10 | | Reception | Functions of the Dedicated Register2 | | Reception Interrupt | General-purpose Register Area | | | (Address: 0100 <sub>H</sub> to 01FF <sub>H</sub> )2 | | Reception Operations | Higher Address Set Register (WRARH)35 | | Reception Operations (Operating Mode 0.1 or 3) 307 | Lower Address Set Register (WRARL)35 | | (Operating Mode 0,1,or 3) | Operation Order of the Wild Register Function | | Reception Operations (Operating Mode 2 Oply) 200 | 35 | | (Operating Mode 2 Only)309 | PWM Compare Register (COMR)14 | | Register | PWM Control Register (CNTR)14 | | 12-bit PPG Control Register 1 (RCR21) 214 | | | Register and Vector Table Related to 8/16-bit Capture | Register Bank Pointer | |-------------------------------------------------------------------------------|------------------------------------------------------------------------| | Timer/Counter of Interrupts184 | Configuration of the Register Bank Pointer (RP) | | Register and Vector Table Related to Interrupts from | 31 | | Time-base Timer121 | Reset | | Register and Vector Table Related to the Interrupt of | Block Diagram of External Reset Pin47 | | the A/D Converter272 | Function of the External Reset Pin47 | | Register and Vector Table Related to the Interrupts of | Influence from a Reset of Contents in RAM 49 | | an 8-bit PWM Timer147 | Input of a Hardware Reset (\overline{RST}) | | Register Associated with Interrupt Generation by | Overview of the Reset Operation | | External Interrupt Circuit 1 and Vector Table | Setting the Read/Reset State | | 238 | Software Reset, Watchdog Timer Reset 373 | | Register Associated with Interrupt Generation by | State of Reset Waiting for Stabilization of Oscillation | | External Interrupt Circuit 2 and Vector | 49 | | Table253 | States of Pins during Reset50 | | Registers Associated with 12-bit PPG Timer | Reset Flag Register | | 213 | Configuration of the Reset Flag Register (RSFR) | | Registers Associated with External Interrupt Circuit 1 | 45 | | 231 | Reset Sources | | Registers Associated with External Interrupt Circuit 2 | Reset Sources | | 249 | Reset Sources and Oscillation Stabilization Wait | | Registers of 8/16-bit Capture Timer/Counter | Time | | 170 | | | Registers of 8-bit Serial I/O319 | Reset Waiting State of Passet Waiting for Stabilization of Ossillation | | Registers of Port 491 | State of Reset Waiting for Stabilization of Oscillation 49 | | Registers of Port 595 | | | Registers PDR0, DDR0, and PUL0 of Port 079 | RP | | Registers PDR3, DDR3, and PUL3 of Port 385 | Configuration of the Register Bank Pointer (RP) | | Registers PDR6, DDR6, and PUL6 of Port 6 102 | 31 | | Registers PDR7, DDR7, and PUL7 of Port 7 108 | RSFR | | Registers Related to the 8-bit PWM Timer142 | Configuration of the Reset Flag Register (RSFR) | | Registers Related to the A/D Converter | 45 | | Registers Related to the Wild Register Function | RST | | 350 | Input of a Hardware Reset (RST) | | Serial Data Register (SDR) | RST pin | | Serial Input Data Register (SIDR) | High voltage supply on RST pin | | Serial Mode Control Register (SMC)290 | (applicable to MB89F202RA only) | | Serial Mode Register (SMR) | 358 | | Serial Output Data Register (SODR)298 | | | Serial Rate Control Register (SRC) | S | | Serial Status and Data Register (SSD)294 | enn | | Serial Switch Register (SSEL) | SDR | | Standby Control Register (STBC) | Serial Data Register (SDR) | | Time-base Timer Control Register (TBTC)119 Timer O Control Register (TCRO)173 | Serial Data Register | | Timer 0 Control Register (TCR0) | Serial Data Register (SDR) | | Timer 0 Data Register (TDR0) | Serial Function Switching | | Timer 1 Control Register (TCR1) | Serial Function Switching | | Timer 1 Data Register (TDR1) | Serial I/O | | Timer Output Control Register (TCR2) | 8-bit Serial I/O Interrupt Register and Vector Table | | UART Interrupt Related Registers and Vector Table | 324 | | Addresses | Block Diagram for 8-bit Serial I/O Pins 318 | | UART-relating Registers | Block Diagram of 8-bit Serial I/O315 | | Wild Posister Addresses List | Interrupt at Serial I/O Operation | | Wild Register Addresses List | Notes on Using 8-bit Serial I/O | | Wild Register Applicable Addresses | Pins of 8-bit Serial I/O317 | | Wild Register Function348 | Registers of 8-bit Serial I/O319 | | | Serial I/O Function314 | | | | | When Bidirectional Serial I/O Operation is Performed | Stabilization of Oscillation | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--|--| | 334 | State of Reset Waiting for Stabilization of Oscillation | | | | Serial Input | 49 | | | | Operation at Serial Input Completion328 | Stack | | | | Program Example for 8-bit Serial Input | 16-bit Data Storage State in Stack26 | | | | Serial Input Operation327 | Stack Area | | | | Serial Input Data Register | Stack Area for Interrupt Processing42 | | | | Serial Input Data Register (SIDR)297 | Stack Operation | | | | Serial Mode Control Register | Stack Operation at the Beginning of Interrupt | | | | Serial Mode Control Register (SMC)290 | Processing41 | | | | Serial Mode Register | Stack Operation at the End of Interrupt Processing | | | | Serial Mode Register (SMR)320 | 41 | | | | Serial Output | Standby Control Register | | | | Operation at Serial Output Completion 326 | Standby Control Register (STBC)66 | | | | Program Example for 8-bit Serial Output 336 | Standby Mode | | | | Serial Output Operation325 | Cancellation of Standby Mode by an Interrupt | | | | Serial Output Data Register | 70 | | | | Serial Output Data Register (SODR)298 | Diagram for State Transition in Standby Mode | | | | Serial Rate Control Register | 88 | | | | Serial Rate Control Register (SRC)292 | Notes on Setting Standby Mode70 | | | | Serial Status and Data Register | Operation in Standby Mode and at Halfway Stop | | | | Serial Status and Data Register (SSD) | 197 | | | | Serial Switch | Operations in Standby Mode63 | | | | Serial Switch | Operations in the Standby Mode and at a Suspension | | | | Serial Switch Register | 152 | | | | Serial Switch Register (SSEL) | Standby Mode | | | | | Transition to Standby Mode and Interrupt70 | | | | Setting Setting the Read/Reset State 269 | State | | | | Setting the Read/Reset State | State of Reset Waiting for Stabilization of Oscillation | | | | SIDR CONTRACTOR OF THE CONTRAC | 49 | | | | Serial Input Data Register (SIDR) | States of Pins after the CPU Reads the Mode Data | | | | Single-chip Mode | States of Directories Depart | | | | Single-chip Mode72 | States of Pins during Reset | | | | Sleep Mode | STBC | | | | Operations Related to Sleep Mode64 | Standby Control Register (STBC)66 | | | | SMC | Steps | | | | Serial Mode Control Register (SMC) | Steps in the Interrupt Operation37 | | | | SMR | Stop Mode | | | | Serial Mode Register (SMR)320 | Operations Related to Stop Mode65 | | | | SODR | Structure | | | | Serial Output Data Register (SODR)298 | Structure of Port 078 | | | | Software Reset | Structure of Port 384 | | | | Software Reset, Watchdog Timer Reset 373 | Structure of Port 490 | | | | Special Instructions | Structure of Port 5 | | | | Special Instructions | Structure of Port 6 | | | | Square Wave | Structure of Port 7107 | | | | Interval Timer Functions (Functions to Output | Suspension | | | | the Square Wave)136 | Operations in the Standby Mode and at a Suspension | | | | SRC | 152 | | | | Serial Rate Control Register (SRC)292 | SYCC | | | | SSD | Configuration of the System Clock Control Register | | | | Serial Status and Data Register (SSD)294 | (SYCC)56 | | | | SSEL | System Clock Control Register | | | | Serial Switch Register (SSEL)301 | Configuration of the System Clock Control Register | | | | benar bytten Register (bbEL) | (SYCC) 56 | | | | т | Transition to Standby Mode and Interrupt70 | |------------------------------------------------------|---------------------------------------------------------| | TBTC | Transmission | | Time-base Timer Control Register (TBTC)119 | Transmission Interrupt303 | | TCCR | Transmission Operations | | Capture Control Register (TCCR)171 | Transmission Operations in Operating Mode is | | TCPH and TCPL | 0,1,2,or 3306 | | Capture Data Registers H and L (TCPH and TCPL) | | | 182 | U | | TCR | UART | | Timer 0 Control Register (TCR0)173 | Block Diagram of the UART-relating Pins | | Timer 1 Control Register (TCR1)175 | 288 | | Timer Output Control Register (TCR2)177 | Block Diagram of UART284 | | TDR | Functions of UART280 | | Timer 0 Data Register (TDR0)178 | Program Example for UART311 | | Timer 1 Data Register (TDR1)180 | UART Relating Pins287 | | Theory | UART-relating Registers | | Theory of Operation for Operating Mode 0,1,2, and 3 | UART Interrupt Related Registers | | 305 | UART Interrupt Related Registers and Vector Table | | Time-base Timer | Addresses | | Block Diagram of Time-base Timer118 | UART-relating Registers | | Notes on Using Time-base Timer124 | UART-relating Registers | | Operations of Interval Timer Function | UPC | | (Time-base Timer)122 | Clock Divider Selection Register (UPC) 299 | | Operations of Time-base Timer122 | | | Oscillation Stabilization Time and Time-base Timer | V | | Interrupts121 | Markey Tallie | | Programming Examples for Time-base Timer | Vector Table | | 125 | 8-bit Serial I/O Interrupt Register and Vector Table324 | | Register and Vector Table Related to Interrupts from | Register and Vector Table Related to 8/16-bit Capture | | Time-base Timer121 | Timer/Counter of Interrupts184 | | Time-base Timer Control Register | Register and Vector Table Related to Interrupts from | | Time-base Timer Control Register (TBTC)119 | Time-base Timer | | Timer 0 Control Register | Register and Vector Table Related to the Interrupt of | | Timer 0 Control Register (TCR0)173 | the A/D Converter272 | | Timer 0 Data Register | Register and Vector Table Related to the Interrupts of | | Timer 0 Data Register (TDR0)178 | an 8-bit PWM Timer 147 | | Timer 1 Control Register | Register Associated with Interrupt Generation by | | Timer 1 Control Register (TCR1)175 | External Interrupt Circuit 1 and Vector | | Timer 1 Data Register | Table | | Timer 1 Data Register (TDR1)180 | Register Associated with Interrupt Generation by | | Timer Output Control Register | External Interrupt Circuit 2 and Vector | | Timer Output Control Register (TCR2)177 | Table | | t <sub>INST</sub> | UART Interrupt Related Registers and Vector Table | | Instruction Cycle (t <sub>INST</sub> )57 | Addresses | | Transfer | Vector Table Area | | Transfer Instructions392 | Vector Table Area | | Transfer Clock Rate | (Address: FFC0 <sub>H</sub> to FFFF <sub>H</sub> )24 | | Choice of the Transfer Clock Rate | | | Transferred Data Format | W | | Transferred Data Format | Watchdog Control Register | | Transition | Watchdog Control Register (WDTC)130 | | Diagram for State Transition in Standby Mode | Watchdog Timer | | 68 | Block Diagram of Watchdog Timer 129 | | | Notes on Using Watchdog Timer132 | | Operations of Watchdog Timer | WRARL | |-------------------------------------------------|--------------------------------------------------| | Programming Examples of Watchdog Timer | Lower Address Set Register (WRARL)353 | | 133 | WRDR | | Software Reset, Watchdog Timer Reset 373 | Data Setting Register (WRDR)351 | | Watchdog Timer Function | WREN | | WDTC | Address Comparison EN Register (WREN)354 | | Watchdog Control Register (WDTC) 130 | Write | | Wild Register | Automatic Write/Erase364, 365, 366 | | Block Diagram of the Wild Register Function | Detailed Explanation of Flash Memory Write/Erase | | 349 | 367 | | Operation Order of the Wild Register Function | Write363 | | | Writing | | Registers Related to the Wild Register Function | Notes on Writing Data369 | | 350 | Writing Data369 | | Wild Register Addresses List | Writing to the Flash Memory369 | | Wild Register Applicable Addresses | Writing to/Erasing Flash Memory358 | | Wild Register Function348 | Writing Data | | WRARH | Writing Data369 | | Higher Address Set Register (WRARH) | - | CM25-10153-2E ## FUJITSU SEMICONDUCTOR • CONTROLLER MANUAL F<sup>2</sup>MC-8L 8-BIT MICROCONTROLLER MB89202/F202RA Series HARDWARE MANUAL February 2008 the second edition Published **FUJITSU LIMITED** Electronic Devices Edited Strategic Business Development Dept.